时间:2021-07-01 10:21:17 帮助过:47人阅读
这也是查询扩展的一项任务。在使用查询扩展时,MySQL对数据和索引进行两遍扫描来完成搜索:
1.首先,进行一个基本的全文本搜索,找出与搜索条件匹配的所有行;
2.其次,MySQL检查这些匹配行并选择所有有用的词(我们将会简要地解释MySQL如何断定什么有用,什么无用)。
3.再其次,MySQL再次进行全文本搜索,这次不仅使用原来的条件,而且还使用所有有用的词。
利用查询扩展,能找出可能相关的结果,即使它们并不精确包含所查找的词。
只用于MySQL版本4.1.1或更高级的版本 查询扩展功能是在MySQL 4.1.1中引入的,因此不能用于之前的版本。
下面举一个例子,首先进行一个简单的全文本搜索,没有查询扩展:
输入:
select note_text from productnotes where match(note_text) against('anvils');
输出:
分析:只有一行包含词 anvils ,因此只返回一行。
下面是相同的搜索,这次使用查询扩展:
输入:
select note_text from productnotes where match(note_text) against('anvils' with query expansion);
输出:
分析:这次返回了7行。第一行包含词 anvils ,因此等级最高。第二行与 anvils 无关,但因为它包含第一行中的两个词( customer和 recommend ),所以也被检索出来。第3行也包含这两个相同的词,但它们在文本中的位置更靠后且分开得更远,因此也包含这一行,但等级为第三。第三行确实也没有涉及 anvils (按它们的产品名)。
正如所见,查询扩展极大地增加了返回的行数,但这样做也增加了你实际上并不想要的行的数目。
行越多越好 表中的行越多(这些行中的文本就越多),使用查询扩展返回的结果越好。
以上就是mysql查询扩展技术教程的详细内容,更多请关注Gxl网其它相关文章!