MySQL索引下推(5.6版本+)

索引下推(听着高大上,就是一层窗户纸而已)

有了索引下推优化,可以在有like条件查询的情况下,减少回表次数。

对于user_table表,我们现在有(username,age)联合索引
如果现在有一个需求,查出名称中以“张”开头且年龄小于等于10的用户信息,语句如下:

select * from user_table where username like '张%' and age > 10

语句有两种执行可能:

  1. 根据(username,age)联合索引查询所有满足名称以“张”开头的索引,然后回表查询出相应的全行数据,然后再筛选出满足年龄小于等于10的用户数据
  2. 根据(username,age)联合索引查询所有满足名称以“张”开头的索引,然后直接再筛选出年龄小于等于10的索引,之后再回表查询全行数据。

明显的,第二种方式需要回表查询的全行数据比较少,这就是mysql的索引下推。mysql默认启用索引下推,我们也可以通过修改系统变量optimizer_switch的index_condition_pushdown标志来控制
SET optimizer_switch = 'index_condition_pushdown=off';

 

详情请点击:https://blog.csdn.net/mccand1234/article/details/95799942

发布了732 篇原创文章 · 获赞 336 · 访问量 77万+

猜你喜欢

转载自blog.csdn.net/a772304419/article/details/103890894