在 SQLite FTS3 搜索中包含部分匹配项

gc2*_*c20 3 sql sqlite search full-text-search fts3

我的简单 SQLite FTS3 实现目前将用户查询与存储的结果匹配并返回它们,只要这些结果包含用户查询中的所有单词(换句话说,FTS 表是使用简单的标记器创建的)。

现在,我想让搜索更加智能,我希望它根据查询中匹配结果的单词数对结果进行排名/排序。例如,

SELECT name FROM nametable WHERE name MATCH 'fast food restaurant'  
Run Code Online (Sandbox Code Playgroud)

目前返回

SUBWAY FAST FOOD RESTAURANT
MCDONALDS FAST FOOD RESTAURANT
Run Code Online (Sandbox Code Playgroud)

应该回来

SUBWAY FAST FOOD RESTAURANT
MCDONALDS FAST FOOD RESTAURANT
CHIPOTLE FAST FOOD
PIZZA FAST FOOD
GOOD FOOD OUTLET
Run Code Online (Sandbox Code Playgroud)

以该顺序。换句话说,搜索输出不应限于必须包含用户查询的所有单词的结果,而是将包含所有单词的结果放置在列表中较高的位置,同时为返回部分匹配的结果留出空间。

执行此操作的一种简单方法是使用用户输入的所有排列运行多个查询,并将结果按所需顺序 UNION,但这样效率很低。

Fre*_*hez 7

更容易做到:

SELECT name FROM nametable WHERE name MATCH 'fast OR food OR restaurant'
Run Code Online (Sandbox Code Playgroud)

无需处理多个查询。