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

时间:2011-07-01 03:43:55

标签: sql search sqlite full-text-search fts3

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

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

SELECT name FROM nametable WHERE name MATCH 'fast food restaurant'  

目前返回

SUBWAY FAST FOOD RESTAURANT
MCDONALDS FAST FOOD RESTAURANT

应该返回

SUBWAY FAST FOOD RESTAURANT
MCDONALDS FAST FOOD RESTAURANT
CHIPOTLE FAST FOOD
PIZZA FAST FOOD
GOOD FOOD OUTLET

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

这样做的一个简单方法是使用用户输入的所有排列运行多个查询,并按所需顺序UNION结果,但这样效率会相当低。

2 个答案:

答案 0 :(得分:4)

更容易做到:

SELECT name FROM nametable WHERE name MATCH 'fast OR food OR restaurant'

无需处理多个查询。

答案 1 :(得分:3)

这是一个未经考验的想法。

SELECT name
FROM (
      SELECT name, 1 as matched
      FROM nametable
      WHERE name MATCH 'fast'
    UNION ALL
      SELECT name, 1 as matched
      FROM nametable
      WHERE name MATCH 'food'
    UNION ALL
      SELECT name, 1 as matched
      FROM nametable
      WHERE name MATCH 'restaurant'
  )
GROUP BY name
ORDER BY SUM(matched) DESC, name