索引的操作解析(覆盖,回表,下推)(需补充)

概念:

覆盖索引:extra 值:using index 

   语句用到的所有列要被所使用的索引覆盖,不需要从数据表中读取数据(包括select,join和where子句使用到的列)

图1 

 

图2

测试联合索引:

先添加联合索引:

图3

 

下图:using index即从索引中就能找到数据,但是需要根据where条件过滤,所用到using where(过滤),此时没有回表

图4

 

图5

(暂时还不清楚非聚集索引,后面再补充)

 

回表查询:

    通过索引不能获取所有的数据,还要根据索引回到表数据中获取数据(个人理解)

     网上博客对回表的定义:

       1. extra的值有using index condition二级索引无法直接查询所有列的数据,二级索引里面包含主键,此时(二级索引作为前提条件)通过主键查询表的记录称为回表。using index condition是指sql中有索引下推时extra的标识。感觉索引下推一定会回表,但回表不一定会索引下推

       2.extra 有using where   但是using where 只是表示有筛选条件,但筛选条件可以在索引中筛选,所以也可以不用回表(图4),但下图6应该是做了回表操作了

图6

所以我认为extra没有特殊的标识来表示回表操作

 

索引下推ICP(Index Condition Pushdown):

mysql有service层和引擎层,之前在service层做的筛选操作,其中的索引筛选现在可以“下推”到引擎层。

 

图7

 

图8

图9

上图需要使用二级索引理解,后续补充

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值