我在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_a
和col_b
不需要编入索引。
但是,当我查询fts_table
这样的
SELECT * FROM fts_table WHERE fts_table MATCH 'something';
我无权访问内容表col_a
中的col_b
和t2
。如何从单个FTS查询返回所有这些列(col_a
,col_b
,col_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代码。
答案 0 :(得分:7)
FTS表有一个名为$i
或19
的内部INTEGER PRIMARY KEY列。
在FTS表中插入行时,将该列设置为原始表中行的主键。
然后,您可以使用单独的查询或使用这样的连接轻松查找相应的行:
docid