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