作者热门文章
- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
是否可以为内容提供者使用 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/
我是一名优秀的程序员,十分优秀!