如何在SQLite中使用FTS3

时间:2013-08-27 13:26:06

标签: android sqlite fts3

我有几乎200k条目的表。当我尝试用LIKE搜索时,它非常慢。现在我决定使用FTS。所以我创建了两个索引来进行搜索。然后我创建了fts虚拟表。

`CREATE TABLE [search_eng] (
  [id] INTEGER PRIMARY KEY AUTOINCREMENT, 
  [entry_id] INTEGER, 
  [re_value] TEXT, 
  [ke_value] TEXT, 
  [g_value] TEXT);

CREATE INDEX idx_se_re ON search_eng (re_value);

CREATE INDEX idx_se_gv ON search_eng (g_value);


CREATE VIRTUAL TABLE search_eng_fts USING fts3(id, entry_id, re_value, ke_value, g_value);`

我不知道如何使用新创建的FTS表。所以我的问题是如何使用该虚拟表进行搜索?你能举个例子吗?

1 个答案:

答案 0 :(得分:7)

the documentation中解释了这一点。

您不需要两个FTS搜索索引。

您应该将id列声明为INTEGER PRIMARY KEY。 您可能不需要FST表中的entry_id列。

将文本复制到FTS表中:

INSERT INTO search_eng_fts(id, re_value, ke_value, g_value)
SELECT id, re_value, ke_value, g_value FROM search_eng;

然后您可以使用MATCH运算符在该表中进行搜索:

SELECT id FROM search_eng_fts WHERE re_value MATCH 'hello';