本文主要是介绍mysql必知必会--学习笔记(11)--全文本搜索FULLTEXT,Match,Against,布尔全文搜索,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1、mysql的引擎中MYISAM支持全文本搜索,而InnoDB不支持文本搜索。
2、为了进行全文本搜索,必须索引被搜索的列,而且要随着数据的改变不断地重新索引。
一般在创建表时启用全文本搜索。 CREATE TABLE 语句接受 FULLTEXT 子句,它给出被索引列的一个逗号分隔的列表。
在定义之后,MySQL自动维护该索引。在增加、更新或删除行时,索引随之自动更新。
3、在索引之后,使用两个函数 Match() 和 Against() 执行全文本搜索,其中 Match() 指定被搜索的列, Against() 指定要使用的搜索表达式。
使用完整的 Match() 说明:传递给 Match() 的值必须与FULLTEXT() 定义中的相同。如果指定多个列,则必须列出它们(而且次序正确)。
搜索不区分大小写 :除非使用 BINARY 方式(本章中没有介绍),否则全文本搜索不区分大小写。
4、在 SELECT 而不是 WHERE 子句中使用 Match() 和 Against() 。这使所有行都被返回。此列包含全文本搜索计算出的等级
值。等级由MySQL根据行中词的数目、唯一词的数目、整个索引中词的总数以及包含该词的行的数目计算出来。
5、全文本搜索的结果 (排除那些等级为0的行) (按等级以降序排序)。
6、使用查询扩展
首先,进行一个基本的全文本搜索,找出与搜索条件匹配的所有
行;
其次,MySQL检查这些匹配行并选择所有有用的词(我们将会简
要地解释MySQL如何断定什么有用,什么无用)。
再其次,MySQL再次进行全文本搜索,这次不仅使用原来的条件,
而且还使用所有有用的词。
7、查询扩展实例
SELECT note_text FROM productnotes WHERE Match(note_text) AGAINST('heavy' WITH QUERY EXPANSION);
8、布尔文本搜索
即使没有 FULLTEXT 索引也可以使用,但效率非常低下
9、关键字 IN BOOLEAN MODE的作用演示
SELECT note_text FROM productnotes WHERE Match(note_text) AGAINST('heavy' IN BOOLEAN MODE);
10、为了匹配包含 heavy 但不包含任意以 rope 开始的词的行,可使用以下
查询:
SELECT note_text
FROM productnotes
WHERE Match(note_text)
AGAINST('heavy -rope*' IN BOOLEAN MODE);
11、全文本布尔操作符
+ | 包含,词必须存在 |
- | 排除,词必须不出现 |
> | 包含,而且增加等级值 |
< | 包含,且减少等级值 |
() | 把词组成子表达式(允许这些子表达式作为一个组被包含、排除、排列等) |
~ | 取消一个词的排序值 |
* | 词尾的通配符 |
"" | 定义一个短语(与单个词的列表不一样,它匹配整个短语以便包含或排除这个短语) |
排列而不排序 在布尔方式中,不按等级值降序排序返回的行
12、知识点:
许多词出现的频率很高,搜索它们没有用处(返回太多的结果)。
因此,MySQL规定了一条50%规则,如果一个词出现在50%以上
的行中,则将它作为一个非用词忽略。50%规则不用于 IN BOOLEAN
MODE 。
如果表中的行数少于3行,则全文本搜索不返回结果(因为每个词
或者不出现,或者至少出现在50%的行中)。
忽略词中的单引号。例如, don't 索引为 dont 。
不具有词分隔符(包括日语和汉语)的语言不能恰当地返回全文
本搜索结果。
这篇关于mysql必知必会--学习笔记(11)--全文本搜索FULLTEXT,Match,Against,布尔全文搜索的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!