当前位置:  开发笔记 > 数据库 > 正文

SQLiteDatabase.insert()为虚拟表返回不正确的rowid

如何解决《SQLiteDatabase.insert()为虚拟表返回不正确的rowid》经验,为你挑选了0个好方法。

当我在一个全文搜索数据库中插入一行时声明如下:

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管理表中也插入了一行.

推荐阅读
小色米虫_524
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有