可以为内容提供者使用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/

10-08 21:40