返回 登录
0

如何使用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查询扩展示例

让我们来看一个查询扩展的例子,看看它是如何工作的。
我们将使用product表的产品名称(product_name)列来演示查询扩展功能。 首先,在product_name列上启用全文搜索索引

ALTER TABLE studymysql.product
ADD FULLTEXT(product_name);

第二步,搜索名称包含Huawei字符项便不使用查询扩展的产品。

mysql> SELECT product_name
FROM studymysql.product
WHERE MATCH(product_name) AGAINST('Huawei');
+--------------------------------------------------------------+
| product_name                                                 |
+--------------------------------------------------------------+
| Huawei/华为 揽阅M2 10.0 WIFI 16GB 10英寸八核平板电脑         |
| Huawei/华为 PLE-703L 4G 16GB M2青春版平板电脑手机            |
| Huawei/华为 PLE-703L 4G 32GB青春版双卡双待全网通手机平板电脑 |
| Huawei/华为 M2 10.0 WIFI 64GB平板电脑英寸高清八核M2-A01w     |
+--------------------------------------------------------------+
4 rows in set

如上面的结果中,搜索结果中其名称包含术语Huawei4个产品。
第三步,使用查询扩展来扩大搜索结果,如以下的语句:

SELECT product_name
FROM studymysql.product
WHERE MATCH(product_name) 
      AGAINST('Win10' WITH QUERY EXPANSION);

执行上面的查询语句,结果如下所示 -

当我们使用查询扩展时,在搜索结果中有更多的行。前两行是最相关的,后面的其他行是来自前两行中的相关关键字,例如WIFI

注意,盲查询扩展往往通过返回不相关的结果,明显会增加噪声。强烈建议仅在搜索的关键字较短时使用查询扩展。

在本教程中,我们已经介绍了MySQL查询扩展,以便在用户提供的关键字较短时扩大搜索结果。

相关教程

评论