深入浅出索引(下)


问:联合索引的技巧考虑方向有哪些?

回表

  • 普通索引查询,都是先查询出主键索引再根据主键索引查出内容数据。回到主键索引树搜索的过程称之为回表。

覆盖索引

  • 联合索引的字段或是主键,如果查询条件使用的是普通索引(或是联合索引的最左原则字段),查询结果是联合索引的字段或是主键,不用回表操作,直接返回结果,减少 IO 磁盘读写读取整行数据。
  • 由于覆盖索引可以减少树的搜索次数,显著提升查询性能,所以使用覆盖索引是一个常用的性能优化手段。

最左前缀原则

  • 联合索引的最左 N 个字段,也可以是字符串索引的最左 M 个字符。
  • 在建立联合索引的时候,如何安排索引内的字段顺序?
    • 索引的复用能力。因为可以支持最左前缀,所以当已经有了 (a,b) 这个联合索引后,一般就不需要单独在 a 上建立索引了。因此,第一原则是,如果通过调整顺序,可以少维护一个索引,那么这个顺序往往就是需要优先考虑采用的
    • 还有个要考虑的原则就是空间。比如 name 字段是比 age 字段大的 ,那就建议创建一个(name,age) 的联合索引和一个 (age) 的单字段索引。
  • 根据创建联合索引的顺序,以最左原则进行 where 检索,比如(age,name)以 age=1 或 age= 1 and name=‘张三’ 可以使用索引,单以name=‘张三’ 不会使用索引,考虑到存储空间的问题,还请根据业务需求,将查找频繁的数据进行靠左创建索引。

索引下推

上一段我们说到满足最左前缀原则的时候,最左前缀可以用于在索引中定位记录。这时,你可能要问,那些不符合最左前缀的部分,会怎么样呢?

  • 对于 like 'hello%' and age >10 检索,假设有(name,age)联合索引
    • MySQL 5.6 版本之前,会对匹配的数据进行回表查询。
      回表
    • MySQL 5.6 版本之后,引入了索引下推优化(index condition pushdown), 可以在索引遍历过程中,对索引中包含的字段先做判断,直接过滤掉不满足条件的记录,减少回表次数。也就是说 MySQL5.6 版本后,会先过滤掉 age<10 的数据,再进行回表查询,减少回表率,提升检索速度。
      索引下推

笔记来源于《极客时间:MySQL实战45讲:深入浅出索引(下)》

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

✦昨夜星辰✦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值