MySQL查询扩展
简介:在本教程中,您将了解MySQL查询扩展,以根据自动相关性反馈扩大搜索结果。
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);
MySQL查询扩展示例
让我们看一下查询扩展的示例,看看它是如何工作的。 我们将使用products
表的productName
列来演示查询扩展功能。
首先,我们为此列启用全文搜索索引。
ALTER TABLE products ADD FULLTEXT(productName);其次,我们搜索产品名称包含
1992
术语而不使用查询扩展的产品。
SELECT productName FROM products WHERE MATCH(productName) AGAINST('1992');
+-----------------------------------+ | productName | +-----------------------------------+ | 1992 Ferrari 360 Spider red | | 1992 Porsche Cayenne Turbo Silver | +-----------------------------------+ 2 rows in set (0.00 sec)如您所见,搜索结果有两个产品,其产品名称包含术语
1992
。
第三,我们可以通过使用查询扩展来扩大搜索结果,如下所示:
SELECT productName FROM products WHERE MATCH(productName) AGAINST('1992' WITH QUERY EXPANSION);
+-------------------------------------+ | productName | +-------------------------------------+ | 1992 Porsche Cayenne Turbo Silver | | 1992 Ferrari 360 Spider red | | 2001 Ferrari Enzo | | 1932 Alfa Romeo 8C2300 Spider Sport | | 1948 Porsche 356-A Roadster | | 1948 Porsche Type 356 Roadster | | 1956 Porsche 356A Coupe | +-------------------------------------+ 7 rows in set (0.00 sec)当我们使用查询扩展时,我们在搜索结果中获得了更多行。前两行是最相关的,其他行来自前两行中的相关关键字,例如,
Ferrari
请注意,盲查询扩展会通过返回不相关的结果而显着增加噪声。强烈建议您仅在搜索关键字较短时使用查询扩展。
在本教程中,我们向您介绍了MySQL查询扩展,以便在用户提供的关键字很短时扩大搜索结果。