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执行引擎的实时计算才知道在执行的时候要不要走索引下推。