【问题标题】:SQLiteDatabase.insert() returns incorrect rowid for virtual tablesSQLiteDatabase.insert() 为虚拟表返回不正确的 rowid
【发布时间】:2010-06-26 07:55:55
【问题描述】:

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

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

【问题讨论】:

  • 你确定Android支持USING fts吗?最后我知道,这不是 Android SQLite 构建的一部分。在过去的几个版本中我没有听到任何关于它的消息,所以也许他们添加了它,但我想他们会提到它。

标签: android sqlite


【解决方案1】:

来自SQLite Full-Text Search

您的表格必须至少包含 1 文本字段。

PS:+1:我不知道Virtual Tables。谢谢。

【讨论】:

  • 在 SQLite 中,所有 FTS3 列都是 TEXT 类型。列的类型规范被忽略 (sqlite.org/fts3.html#section_1_1)。 FTS3 是虚拟表的实现。
  • @user376859:哦,好点。您是否检查了链接中的示例代码?
猜你喜欢
  • 2023-03-27
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-08-29
相关资源
最近更新 更多