Android - sqlite in子句使用数组中的值

Udi*_*dan 23 sql sqlite android

我想执行一个sqlite查询:

select * from table_name where id in (23,343,33,55,43);
Run Code Online (Sandbox Code Playgroud)

in子句中的值需要从字符串数组中获取:

String values[] = {"23","343","33","55","43"}
Run Code Online (Sandbox Code Playgroud)

我怎样才能做到这一点?

10X!

Sam*_*zor 38

我相信一个简单的toString()将主要做的伎俩:

String values[] = {"23","343","33","55","43"};
String inClause = values.toString();

//at this point inClause will look like "[23,343,33,55,43]"
//replace the brackets with parentheses
inClause = inClause.replace("[","(");
inClause = inClause.replace("]",")");

//now inClause will look like  "(23,343,33,55,43)" so use it to construct your SELECT
String select = "select * from table_name where id in " + inClause;
Run Code Online (Sandbox Code Playgroud)

  • 如果您的某些值来自用户输入,您可能会遭受 SQL 注入攻击或至少崩溃。在将用户输入放入 sql 语句之前,您应该查看“DatabaseUtils.html#sqlEscapeString(java.lang.String)”和相关函数。 (2认同)