Mysql索引下推

1、什么是索引下推?

比如说下面这条语句(前提是联合索引为name,age,position),通常情况下,对于第一个name是范围查询,后面的索引就不会生效了,然后在Mysql5.6以及5.6之后的版本是会先让条件变成 name = ‘LiLei’ 这样的常量值(这块不一定对,但是可以这样理解),然后把后面的索引也用上,这就是索引下推。

EXPLAIN SELECT * FROM employees WHERE name like 'LiLei%' AND age = 22 AND position ='manager';

2、索引下推是从什么时候有的?

在Mysql5.6版本就推出了。

3、索引下推的意义在哪里?

就比如说下面这条sql,它的联合索引为name,age,position,那么走的索引肯定是二级索引,走完二级索引之后还需要回表走主键的聚簇索引,如果我们不走索引下推的时候,到时候回表的记录数肯定比走了索引下推时的记录数多,所以当我们走索引下推时,先使用 name = ‘LiLei’ AND age = 22 AND position =‘manager’ 过滤出少量的记录,再回表,肯定效率能高一些,但也不是每次都会走索引下推,这里mysql会根据标的数据量等因素去实时计算是否走索引下推。

EXPLAIN SELECT * FROM employees WHERE name like 'LiLei%' AND age = 22 AND position ='manager';

4、范围查找一般不走索引下推(>、<、=)

还是前面分析的,范围查找可能Mysql认为它数据量很大,走索引下推还不如全表扫描,可能就不走了,但也不一定,还是需要根据Mysql执行引擎的实时计算才知道在执行的时候要不要走索引下推。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值