摘要:在本教程中,您将了解 MySQL 查询扩展,以基于自动相关性反馈来拓宽搜索结果。
MySQL查询扩展简介
通常,用户根据他们的知识搜索信息。他们利用自己的经验想出关键词来搜索信息,有时,这些关键词太短。
为了帮助用户根据这些太短的关键字查找信息,MySQL全文搜索引擎引入了一个称为查询扩展的概念。
查询扩展用于基于自动相关性反馈(或盲查询扩展)来拓宽全文搜索的搜索结果。从技术上讲,MySQL全文搜索引擎在使用查询扩展时执行以下步骤:
- 首先,搜索与搜索查询匹配的所有行。
- 其次,从搜索结果中找到所有行中的相关单词。
- 第三,根据相关词重新搜索,而不是用户指定的原始关键词。
从应用的角度来看,当搜索结果太少时,可以使用查询扩展。您再次执行搜索,但通过查询扩展,为用户提供更多与他们正在寻找的内容相关的信息。
要使用查询扩展,请在AGAINST()
函数中使用WITH QUERY EXPANSION
搜索修饰符。下面说明了使用WITH QUERY EXPANSION
搜索修饰符的查询语法。
SELECT column1, column2
FROM table1
WHERE MATCH(column1,column2)
AGAINST('keyword',WITH QUERY EXPANSION);
Code language: SQL (Structured Query Language) (sql)
MySQL查询扩展示例
让我们看一个使用查询扩展的示例,看看它是如何工作的。
我们将使用products
表的productName
列来演示查询扩展功能。
首先,在productName
列上创建全文搜索索引:
ALTER TABLE products
ADD FULLTEXT(productName);
Code language: SQL (Structured Query Language) (sql)
其次,不使用查询扩展来搜索名称包含1992
产品。
SELECT
productName
FROM
products
WHERE
MATCH (productName)
AGAINST ('1992' );
Code language: SQL (Structured Query Language) (sql)
从输出中可以清楚地看到,搜索结果有两个名称包含术语1992
的产品。
第三,使用查询扩展来扩大搜索结果:
SELECT
productName
FROM
products
WHERE
MATCH(productName)
AGAINST('1992' WITH QUERY EXPANSION);
Code language: SQL (Structured Query Language) (sql)
与查询扩展一起使用时,结果集多了两行。前两行是最相关的,其他行来自前两行中派生的相关关键字,例如Ferrari
请注意,盲目查询扩展往往会通过返回不相关的结果来显着增加噪音。强烈建议您仅在搜索关键字较短时才使用查询扩展。
在本教程中,您学习了如何在搜索查询太短时使用 MySQL 查询扩展来扩大搜索结果。
本教程有帮助吗?