我正在尝试创建一个方法来检索特定表的最大ID.
这是不起作用的代码:
private long getMaxId()
{
String query = "SELECT MAX(id) AS max_id FROM mytable";
Cursor cursor = db.rawQuery(query, new String[] {"max_id"});
int id = 0;
if (cursor.moveToFirst())
{
do
{
id = cursor.getInt(0);
} while(cursor.moveToNext());
}
return id;
}
Run Code Online (Sandbox Code Playgroud)
抛出的异常是这样的:
E/AndroidRuntime(24624): android.database.sqlite.SQLiteException: bind or column index out of range: handle 0x200408
Run Code Online (Sandbox Code Playgroud)
我想问题就是这一行:
id = cursor.getInt(0);
Run Code Online (Sandbox Code Playgroud)
有没有人知道如何解决这个问题?
谢谢.
尝试更换:
Cursor cursor = db.rawQuery(query, new String[] {"max_id"});
Run Code Online (Sandbox Code Playgroud)
同
Cursor cursor = db.rawQuery(query, null);
Run Code Online (Sandbox Code Playgroud)
从rawQuery描述中,对于第二个参数:
您可以在查询中的where子句中包含?s,它将被selectionArgs中的值替换.这些值将绑定为字符串.
由于您的SQL查询中没有任何占位符,因此可能是问题的根源.
| 归档时间: |
|
| 查看次数: |
12399 次 |
| 最近记录: |