您的位置:首页 > 产品设计 > UI/UE

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

2016-03-07 23:44 639 查看
项目中需要使用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即可。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: