可以为内容提供者使用IN子句吗?
我目前正在使用
cursor = contentResolver.query(CONTENT_URI, PROJECTION, "field IN (?)", new String[] { argsBuilder.toString() }, null);
如果我删除
(?)
并仅使用?
,则会收到错误消息。我的光标计数为0。
如果我手动键入并在sqlite3中执行查询,那么它将起作用。
帮助?
最佳答案
使用IN
运算符时,需要在?
数组中提供的每个参数每个逗号分隔一个selectionArgs
。例如。:
String[] selectionArgs = {"red", "black"};
String selection = "color IN (?, ?)";
以下选择正确的计数和正确的
args
:int argcount = 2; // number of IN arguments
String[] args = new String[]{ 1, 2 };
StringBuilder inList = new StringBuilder(argcount * 2);
for (int i = 0; i < argcount; i++) {
if(i > 0) {
inList.append(",");
}
inList.append("?");
}
cursor = contentResolver.query(
CONTENT_URI,
PROJECTION,
"field IN (" + inList.toString() + ")",
args,
null);
关于Android内容提供商查询IN子句,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/7006124/