我在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);
我正在使用外部内容表,因此我不需要在fts_table中存储col_text的重复值.我只索引col_text,因为col_a和col_b不需要编入索引.
但是,当我像这样查询fts_table时
SELECT * FROM fts_table WHERE fts_table MATCH 'something';
我无法访问内容表t2中的col_a和col_b.如何从单个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中使用它并且直到SQLite 3.8才支持notindexed选项,Android直到Android version 5.x才支持它.我需要支持android 4.x.我正在更新此问题以包含Android代码.
解决方法:
FTS表有一个名为docid或rowid的内部INTEGER PRIMARY KEY列.
在FTS表中插入行时,将该列设置为原始表中行的主键.
然后,您可以使用单独的查询或使用如下连接轻松查找相应的行:
SELECT *
FROM t2
WHERE id IN (SELECT docid
FROM fts_table
WHERE col_text MATCH 'something')
原文地址:https://codeday.me/bug/20190612/1222876.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。