Android contentResolver 进行query 条件为where in时出错

项目中需要使用contentResolver通过in操作符对一定范围内的数据进行查询。
使用普通的方案,即直接使用一个“?”构造一个普通的SQL,

String selection = "item_name in ?";
String[] selectionArgs = new String[]{"('value1','value2,'value3')"} ;

会报语法错误。
解决方案大致如下,自己修改即可,经过验证可用。

代码块


Set positionsSet = membersListCursorAdapter.getCurrentCheckedPosition();
List ids = new ArrayList<>();
List 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,开发)