Android contentResolver 进行query 条件为where in时出错
Posted Codingma
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android contentResolver 进行query 条件为where in时出错相关的知识,希望对你有一定的参考价值。
项目中需要使用contentResolver通过in操作符对一定范围内的数据进行查询。
使用普通的方案,即直接使用一个“?”构造一个普通的SQL,
如
String selection = "item_name in ?";
String[] selectionArgs = new String[]"('value1','value2,'value3')" ;
会报语法错误。
解决方案大致如下,自己修改即可,经过验证可用。
代码块
Set<Integer> positionsSet = membersListCursorAdapter.getCurrentCheckedPosition();
List<String> ids = new ArrayList<>();
List<String> parameters = new ArrayList<>();
for (Integer position : positionsSet)
ids.add(String.valueOf(membersListCursorAdapter.getItemId(position)));
parameters.add("?");
getActivity().getContentResolver().delete(
SharedUserTable.CONTENT_URI,
SharedUserTable._ID + " in (" + TextUtils.join(",", parameters) + ")",
ids.toArray(new String[ids.size()])
);
PS:使用db进行query的时候,如果有where in条件,使用rawquery即可。
以上是关于Android contentResolver 进行query 条件为where in时出错的主要内容,如果未能解决你的问题,请参考以下文章
Android开发实践 ContentProvider和ContentResolver
Android 的 ContentResolver.isSyncActive 在实际同步结束之前返回 false
Android、MVVM:在 ViewModel 中调用 ContentResolver
Android4.4 ContentResolver查询图片无效 及 图库删除 添加图片后,ContentResolver不更新的问题解决
Android中利用ContentResolver获取本地音乐和相册
在 Android 7 中,ContentResolver 的方法 openAssetFileDescriptor(vCardUri, "r") 返回 AssetFileDescr