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时出错的主要内容,如果未能解决你的问题,请参考以下文章