MySQL查询扩展
时间:2019-11-20 08:52:21 来源:igfitidea点击:
简介:在本教程中,您将了解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查询扩展示例
让我们看一个使用查询扩展来查看其工作方式的示例。
我们将使用产品表的productName列来演示查询扩展功能。
首先,在productName列上创建全文本搜索索引:
ALTER TABLE products ADD FULLTEXT(productName);
其次,在不使用查询扩展的情况下搜索名称包含1992的产品。
SELECT productName FROM products WHERE MATCH (productName) AGAINST ('1992' );
从输出中可以清楚地看到,搜索结果有两个产品的名称包含术语1992。
第三,使用查询扩展来扩大搜索结果:
SELECT productName FROM products WHERE MATCH(productName) AGAINST('1992' WITH QUERY EXPANSION);
与查询扩展一起使用时,结果集在中还有另外两行。
前两行是最相关的,其他行来自前两行中派生的相关关键字,例如,法拉利
请注意,盲查询扩展会通过返回不相关的结果来显着增加噪声。
强烈建议仅在搜索关键字较短时才使用查询扩展。
在本教程中,您学习了当搜索查询太短时如何使用MySQL查询扩展来扩大搜索结果。