mysql索引的弊端(MySQL 全文索引的原理与缺陷)
mysql索引的弊端
MySQL 全文索引的原理与缺陷MySQL全文索引一种特殊的索引,它会把某个数据表的某个数据列出现过的所有单词生成一份清单。
alter table tablename add fulltext(column1,column2)
说明:
只能在MyISAM数据表中创建
全文索引是以空格或标点隔开才能搜到的,搜中文是搜不到(有专门的应用支持中文分词可以搜中文,但都不理想)
少于3个字符的单词不会被包含在全文索引里,可以通过修改my.cnf修改选项
ft_min_word_len=3
重新启动MySQL服务器,用repair table tablename quick
为有关数据表重新生成全文索引
|
select * from tablename where match(column1,column2) against( 'word1 word2 word3' )>0.001 |
match ... against 把column1,column2数据列中至少包含word1,word2,word3三个单词之一的数据记录查找到,在关键字match后的数据列必须 跟创建全文索引的数据列相同,检索词不区分大小写和先后顺序,少于3个字符的单词通常被忽略。match... against ...表达式返回一个浮点数作为它本身的求值结果,这个数字反映了结果记录与被检索单词的匹配程度。如果没有匹配到任何记录,或者匹配到的结果记录太多反 而被忽略,表达式将返回0,表达式>0.001的作用是排除match的返回值太小的结果记录。
|
select *,match(column1,column2) against ( 'word1 word2 word3' ) as mtch from tablename having mtch>0.01 order by mtch desc limit 5 |
找出最匹配的5条记录,在where字句中不能使用假名,所以用having
布尔全文搜索的性能支持以下操作符:
+word:一个前导的加号表示该单词必须 出现在返回的每一行的开头位置。
-word: 一个前导的减号表示该单词一定不能出现在任何返回的行中。
(无操作符):在默认状态下(当没有指定 + 或–的情况下),该单词可有可无,但含有该单词的行等级较高。这和MATCH() ... AGAINST()不使用IN BOOLEAN MODE修改程序时的运作很类似。
> <这两个操作符用来改变一个单词对赋予某一行的相关值的影响。 > 操作符增强其影响,而 <操作符则减弱其影响。请参见下面的例子。
( )括号用来将单词分成子表达式。括入括号的部分可以被嵌套。
~word:一个前导的代字号用作否定符, 用来否定单词对该行相关性的影响。 这对于标记“noise(无用信息)”的单词很有用。包含这类单词的行较其它行等级低。
word* :搜索以word开头的单词,只允许出现在单词的末尾
"word1 word" :给定单词必须出现在数据记录中,先后顺序也必须匹配,区分字母大小写
|
select * from tablename where match(column1,column2) against ( '+word1 +word2 -word3' in boolean mode') |
布尔检索只能返回1或者0,不再返回表示匹配程度的浮点数
全文索引的缺陷:
1.数据表越大,全文索引效果好,比较小的数据表会返回一些难以理解的结果。
2.全文检索以整个单词作为匹配对象,单词变形(加上后缀,复数形式),就被认为另一个单词。
3.只有由字母,数字,单引号,下划线构成的字符串被认为是单词,带注音符号的字母仍是字母,像C++不再认为是单词
4.不区分大小写
5.只能在MyISAM上使用
6.全文索引创建速度慢,而且对有全文索引的各种数据修改操作也慢
7.不支持中文
以上就是MySQL 全文索引的原理与缺陷的详细内容,更多关于MySQL 全文索引的资料请关注开心学习网其它相关文章!
原文链接:https://blog.yzmcms.com/mysql/101.html
- mysql配置多实例
- SQL SERVER与MySQL数据类型的对应关系
- mysql 8.0.22 winx64安装配置方法图文教程(mysql 8.0.22 winx64安装配置方法图文教程)
- mysql update 多个字段(mysql update case 更新字段值不固定的操作)
- MySQL批量执行SQL脚本文件
- mysql查询条件的优化(MySQL查询优化之查询慢原因和解决技巧)
- mysql8.0关键字段使用(MySQL 8.0新特性之隐藏字段的深入讲解)
- mysql错误代码之1064的解决方案(mysql错误代码之1064的解决方案)
- 常见的mysql优化策略(MySQL pt-slave-restart工具的使用简介)
- 宝塔mysql怎么设置优化(宝塔面板mysql内存占用高如何优化)
- mysql怎么迁移数据(如何把本地mysql迁移到服务器数据库)
- mysqljoin语句用法(MySQL的join buffer原理)
- mysql和mycat半主从复制项目(Linux如何使用 MyCat 实现 MySQL 主从读写分离)
- mysql存储json的方式(MySQL中查询json格式的字段实例详解)
- mysql 分库分表步骤(MySQL读多写少设计方案 - 分库分表还能这么做?)
- mysql8.0设置root密码(MySQL8.0.23版本的root密码重置最优解法)
- 你好,新成理人丨成都理工大学2019级新生开学典礼隆重举行(新成理人丨成都理工大学2019级新生开学典礼隆重举行)
- 这部民警编演的红色话剧,讲述了一个不断追寻的故事(这部民警编演的红色话剧)
- 日本菜有什么好吃(日本菜有什么好吃的做法)
- 韩国泡菜做法(韩国泡菜的做法步骤)
- 泰国旅游攻略(泰国旅游攻略必去景点)
- 越难春卷(越难春卷皮怎么用)
热门推荐
- css3中基本选择符(CSS3 clip-path 用法介绍详解)
- centosdocker镜像安装mysql(linux下利用Docker安装mysql的步骤)
- mysqltruncate分区自定义参数(MySQL truncate table语句的使用)
- dede优化教程(DEDE调用分类及分类下文章并限制标题字数及显示条数)
- 云服务器好在哪你知道吗(美国云服务器怎么选择?美国云服务器选择技巧分享)
- C#中TryParse的用法
- php单例模式教程学习(PHP下用Swoole实现Actor并发模型的方法)
- html5怎么将字体变为红色(Html5自定义字体解决方法)
- python创建pdf(Python玩转PDF的各种骚操作)
- 面试时如何谈自己的优点
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9