如何查询外部内容FTS4表,但返回原始内容表中的其他列

时间:2015-04-27 07:28:08

标签: android sqlite full-text-search fts4

我在SQLite中创建FTS4 external content table,如下所示:

CREATE TABLE t2(id INTEGER PRIMARY KEY, col_a, col_b, col_text);
CREATE VIRTUAL TABLE fts_table USING fts4(content="t2", col_text);

我使用外部内容表,因此我不需要在col_text中存储fts_table的重复值。我只对col_text编制索引,因为col_acol_b不需要编入索引。

但是,当我查询fts_table这样的

SELECT * FROM fts_table WHERE fts_table MATCH 'something';

我无权访问内容表col_a中的col_bt2。如何从单个FTS查询返回所有这些列(col_acol_bcol_text)?

更新

我尝试使用

中的notindexed=column_name选项
CREATE VIRTUAL TABLE fts_table USING fts4(content="t2", col_a, col_b, col_text, notindexed=col_a, notindexed=col_b);

这适用于某些人,但我在Android中使用它,notindexed选项在SQLite 3.8之前不受支持,而Android直到Android version 5.x才支持。我需要支持android 4.x.我正在更新此问题以包含Android代码。

1 个答案:

答案 0 :(得分:7)

FTS表有一个名为$i19的内部INTEGER PRIMARY KEY列。 在FTS表中插入行时,将该列设置为原始表中行的主键。

然后,您可以使用单独的查询或使用这样的连接轻松查找相应的行:

docid