MySql中的like和in走不走索引

本文通过实例分析MySQL中LIKE操作在不同情况下的索引使用,包括'%'在不同位置的影响,以及IN操作符与数据量大小对索引选择的影响。结论显示,LIKE '%某字符%'通常不走索引,而IN操作的数据量较大时也会导致全表扫描。
摘要由CSDN通过智能技术生成

今天我们来实际操作一下
首先我们创建一个用户表进行测试

Like
在这里插入图片描述
在email字段上加一个索引来测试Like关键字
在这里插入图片描述
我们先来复习一下Like语句的几种写法
往大的方向说Like语句由两种写法,分别时%和_。
%:用来匹配若干个字符的出现形式(也可以是0个)
_:用来匹配单个字符的出现形式
工作中我们主要的模糊查询也是%,我们重点来看一个Like的几种写法

  1. select * from t_user where email like ‘你所知道的字符%’

  2. select * from t_user where email like ‘%你所知道的字符’

  3. select * from t_user where email like ‘%你所知道的字符%’
    我们分别来看一下这三种走索引的情况
    先来看第一种写法

    select * from t_user where email like ‘你所知道的字符%’

使用explain分析一下
在这里插入图片描述
很明显这条语句是走索引的。
这里有没有问题呢?我们把数据库中的数据做一下修改这行语

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值