0

我有一个 rawQuery 字符串正在运行,但 SQlite 会抛出此警告:

SQLiteDirectCursorDriver(1058):找到以 ; 结尾的 SQL 字符串

因为报价问题。因此,我尝试在没有真正替换值的查询中使用 SelectionArgs,如下所示:

String query = "SELECT Min(?) as oldest, Max(?) as newest, COUNT(?) as nb_data FROM ? WHERE ? BETWEEN (SELECT Min(?) FROM ?) AND (SELECT Max(?) FROM ?)";
String[] values = new String[] { TS, TS, col_2, table, TS, TS, table, TS, table };
Cursor mCount = database.rawQuery(query, values);

即使使用较少的 SelectionArgs 字符串(仅在查询的“WHERE”部分),我也无法让它工作,因为没有真正的价值替换要求而是占位符。

是否有解决方案来设置这个准备好的语句(使用占位符而不是使用引号或重写原始查询)以避免收到 SQLiteDirectCursorDriver 警告?

4

1 回答 1

0

您只能将参数用于表达式,而不能用于标识符。

为防止出现此警告,只需省略 SQL 查询字符串末尾的分号即可。

于 2012-09-12T16:08:32.743 回答