微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

android – 如何查询外部内容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);

我正在使用外部内容表,因此我不需要在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')

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐