前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL的索引条件下推(index condition pushdown,ICP)

MySQL的索引条件下推(index condition pushdown,ICP)

作者头像
JavaEdge
发布2022-10-28 15:18:56
8030
发布2022-10-28 15:18:56
举报
文章被收录于专栏:JavaEdge

索引下推:不符合索引最左前缀原则,却还能利用复合索引的其他字段,减少回表次数。

最左前缀可用于在索引中定位记录。那不符合最左前缀的部分,会怎样?

用户表联合索引(name, age)为例,现在需检索表中“名字第一个字是张,且年龄是10的所有男孩”:

代码语言:javascript
复制
select * from user where name like '张%' and age=10 and ismale=1;

在搜索索引树时,只能用 “张”,找到第一个满足条件记录ID3。总比全表扫好。然后判断其他条件。

  • MySQL5.6前,只能从ID3开始,一个个回表,到主键索引上找数据行,再对比字段值
  • 5.6引入索引下推优化,在索引遍历过程中,对索引中包含的字段先做判断,直接过滤不满足条件的记录,减少回表次数

ICP是MySQL使用索引从表中检索行的场景优化:

  • 若无ICP,存储引擎会遍历索引,以在基本表中找到行,并将其返回给MySQL Server来评估行的where条件
  • 启用ICP,若能仅使用索引中的列来评估where条件的某些部分,MySQL Server会将此部分的where 条件下推向存储引擎。然后,存储引擎通过使用索引节点来评估推送的索引条件,并且仅当满足时,才是从表中读取的行。 ICP可减少存储引擎必须访问基本表的次数及MySQL Server必须访问存储引擎的次数

1 执行流程图

图里每个虚线箭头表示回表一次。

1.1 无索引下推

(name,age)索引里故意去掉age值,这过程InnoDB并不看age值,只按序把name第一个字是’张’的记录一条条取出来,并回表,共计回表4次。

1.2 索引下推

InnoDB在(name,age)索引内部就开始判断age是否等于10,对不等于10的记录,直接判断并跳过。这个例子中,只需对ID4、ID5这两条记录回表取数据判断,即只需回表2次。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022/10/13 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 执行流程图
    • 1.1 无索引下推
      • 1.2 索引下推
      相关产品与服务
      对象存储
      对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档