当我在一个声明为:
的全文搜索数据库中插入一行时CREATE VIRTUAL TABLE foo USING fts3 (bar);
SQLiteDatabase.insert()方法返回不正确的rowid。如果表声明如下:
CREATE TABLE foo (bar VARCHAR(10));
它返回正确的rowid值。问题是当我使用从方法返回的rowid插入后很快查询数据库时,返回的Cursor没有记录。它只适用于第一次插入数据库。对于后续插入,将返回不正确的rowid。
我是否需要做任何事情才能从SQLiteDatabase.insert()方法中获取正确的rowid?
我正在使用Android SDK版本2.1update1。
谢谢, 丹
更新: 我最终使用hack来使用以下代码获取最后一行id:
private int getLastRowId(SQLiteDatabase db, String table) {
Cursor cursor = null;
try {
cursor = db
.rawQuery(String.format(Locale.US, "SELECT MAX(rowid) FROM %s", table), null);
if (cursor.moveToFirst()) {
return cursor.getInt(0);
} else {
return 0;
}
} finally {
if (cursor != null) {
cursor.close();
}
}
}
在我的情况下,它是安全的,因为只有一个用户可以访问该应用程序。对于服务应用程序,这可能不起作用,具体取决于它的实现/使用方式。
我认为我们遇到了这个问题,因为在fts3表中执行插入操作时,会插入多行。在主题表和fts3管理表中也插入了一行。