mysql索引like查询语句_mysql对于模糊查询like的一些汇总

1、常见用法:

(1)搭配%使用

%代表一个或多个字符的通配符,譬如查询字段name中以大开头的数据:

4aaa2500c270819ad4cc75430305e41d.png

(2)搭配_使用

_代表仅仅一个字符的通配符,把上面那条查询语句中的%改为_,会发现只能查询出下面一条数据:

79964922cd19f19fdcd823769b01c9c1.png

2、使用like模糊查询会导致索引失效,在数据量大的时候会有性能问题

(1)尽量少以%或者_开头进行模糊查询

通过explain执行计划,我们发现,使用like模糊查询时,如果不以%和_开头查询的话,索引还是有效的

62ec69c612716d07556664a16dea1283.png

5023e0ecbb8c8904ca086b274a28cec0.png

以%或者_开头查询,索引失效

f8c9e5438cfe16fdf1376ecdd2d74e4f.png

04309128e2f0be246d10b85517502460.png

(2)使用覆盖索引

当查询的的条件和查询的结果都是索引中的字段的时候,这个索引我们可以称之为覆盖索引,这个时候,使用like模糊查询索引是有效的

b65a571ea6ec00db7691879123a6601c.png

ac8f3e38b9d66528e602ae0cbcd96612.png

InnoDB中主键可以不添加进索引中

注意:使用覆盖索引,对于字段的长度是由要求限制的,一般超过长度,索引也会失效

这里如果我查询中带有descripition字段,则覆盖索引也会失效(我这里的数据库经过测试最多只支持255长度的字段)

d82ac1bb77cbed1241b2b3bea2d4162b.png

823dc01052719f2a7c60592459564eaf.png

e9503290291a427dfdd73be87eec9bfa.png

(3)使用全文索引

给字段建立Full Text索引,然后使用match(...) against(...)进行检索

faed80ee1b0ab1a65943a60ff536bd88.png

4e1f16f1d3abcaf6be23d039bf6630f6.png

注意:这种全文索引方式只对英文单词起作用,对于中文汉字支持不够友好,需要额外去mysql的配置文件做一些配置修改,让它额外支持中文

(4)使用一些额外的全文搜索引擎来解决

Lucene,solr,elasticsearch等等

基本原理是:把mysql配置文件中的ft_min_word_len=3改为1。(没有这项就直接添加),然后新建一个字段来保持分词结果,给这个字段建立全文索引。然后实现一个分词模块,把词语“大家好”拆分为“大 大家 大家好 家 家好 好”。然后用match .. against 来代替like %%,查询出来的结果跟like的结果基本相同(如果分词合理的话),但是效率比like高至少10倍以上。

总结

到此这篇关于mysql对于模糊查询like的文章就介绍到这了,更多相关mysql模糊查询like内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

本文标题: mysql对于模糊查询like的一些汇总

本文地址: http://www.cppcns.com/shujuku/mysql/355192.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值