Mysql:好好的索引,为什么要下推?

共 1653字,需浏览 4分钟

 ·

2022-12-30 18:13

作者|莱乌


前段时间有读者提议讲讲索引下推,这期就把这事儿安排上。多余的前言就不赘述了,我们直接开始。


列位坐好!


- 思维导图 -




回表操作


对于数据库来说,只要涉及到索引,必然绕不过去回表操作。当然这也是我们今天所讲内容的前调基础。


说到回表,我们需要从索引开始说起。别担心,不会长篇大论,这里只是简单讲下主键索引与普通索引,目的是让大家对回表操作有个认识。如果你对回表操作很熟悉了,那么可以跳过这一段。


这里我们只以 Innodb 存储引擎作为讲解对象。


主键索引


主键索引在底层的数据存储是通过 B+ 树来实现的。简单来说,就是除叶子节之外的其他节点都存储的是主键值。而叶子节点上存储的是整行的数据。


大体结构如下图所示。



非主键索引


除了主键索引外,其它的索引都被称为非主键索引。与主键索引不同的是,非主键索引的叶子节点上存储的是主键的值。




那让我们再回到开始的问题,什么是回表操作?


当我们在非主键索引上查找一行数据的时候,此时的查找方式是先搜索非主键索引树,拿到对应的主键值,再到主键索引树上查找对应的行数据。


这种操作就叫作回表操作。


好了,这里你应该了解了什么是回表操作了。简单来讲,就是在非主键索引树上拿到对应的主键值,然后回到主键索引上找到对应的行数据。


这样做的前提条件是,所要查找的字段不存在于非主键索引树上。





低版本操作


讲完了回表操作,让我们继续回到这篇文章的主题——索引下推。


其实在 Mysql 5.6 版本之前是没有索引下推这个功能的,从 5.6 版本后才加上了这个优化项。所以在引出索引下推前还是先回顾下没有这个功能时是怎样一种处理方式。


我们以一个真实例子来进行讲解。


在这里有张用户表 user,记录着用户的姓名,性别,身高,年龄等信息。表中 id 是自增主键,(name,sex) 是联合索引。在这里用 1 表示男,2 表示女。现在需要查找所有姓王的男性信息。


SQL 实现起来很简单:



但是它的实现原理是什么呢?


根据联合索引最左前缀原则,我们在非主键索引树上找到第一个满足条件的值时,通过叶子节点记录的主键值再回到主键索引树上查找到对应的行数据,再对比是否为当前所要查找的性别。


整个原理可以用下边的图进行表示。



看到了吧,低版本中需要每条数据都进行回表,增加了树的搜索次数。如果遇到所要查找的数据量很大的话,性能必然有所缺失。





高版本操作


讲完了低版本操作,让我们继续回到这篇文章的主题——索引下推。


知道了痛点,那么怎么解决。很简单,只有符合条件了再进行回表。结合我们的例子来说就是当满足了性别 sex = 1 了,再回表查找。这样原本可能需要进行回表查找 4 次,现在可能只需要 2 次就可以了。



所以本质来说,索引下推就是只有符合条件再进行回表,对索引中包含的字段先进行判断,不符合条件的跳过。减少了不必要的回表操作。





总结


回表操作

  • 当所要查找的字段不在非主键索引树上时,需要通过叶子节点的主键值去主键索引上获取对应的行数据,这个过程称为回表操作。


索引下推

  • 索引下推主要是减少了不必要的回表操作。对于查找出来的数据,先过滤掉不符合条件的,其余的再去主键索引树上查找。


新上课程



课程:MySQL数据库入门实战- Python版
课程介绍:MySQL是当前互联网非常重要的数据存储技术,大量的用户信息、订单信息、客户信息都存储在MySQL,掌握MySQL甚至成为衡量一名程序员的重要技术,而非技术的运营、产品也经常需要使用SQL去查询数据进行分析。
本课程讲解MYSQL的使用技术,结合Python语言的应用,也实现了自动化的操作和处理。
讲师:裴帅帅
讲师介绍:前百度资深大数据工程师,现某一线互联网推荐系统架构师,8年大数据、机器学习研发经验,常年使用和实战Python/Java双语言。
课程优惠:原价198元,目前上线限时 5 折优惠,普通用户只需要99即可获得该门课程永久权限
VIP 用户无需付费,在线即可观看该课程。
课程链接:长按扫码 ↓ 立即前往课程页面



点击
阅读原文
,立即前往课程页面
浏览 9
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报