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

时间:2012-02-08 23:34:56

标签: android sql sqlite

我想执行一个sqlite查询:

select * from table_name where id in (23,343,33,55,43);

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

String values[] = {"23","343","33","55","43"}

我怎样才能做到这一点?

10X!

1 个答案:

答案 0 :(得分:37)

我相信一个简单的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;