Mysql性能优化:为什么要用覆盖索引?

Mysql性能优化:为什么要用覆盖索引?导读 相信读者看过很多MYSQL索引优化的文章,其中有很多优化的方法,比如最佳左前缀,覆盖索引等方法,但是你真正理解为什么要使用最佳左前缀,为什么使用覆盖索引会提升查询的效率吗? 本篇文章将从MYSQ

Mysql性能优化:为什么要用覆盖索引?

导读

 

  • 相信读者看过很多MYSQL索引优化的文章,其中有很多优化的方法,比如最佳左前缀,覆盖索引等方法,但是你真正理解为什么要使用最佳左前缀,为什么使用覆盖索引会提升查询的效率吗?

  • 本篇文章将从MYSQL内部结构上讲一下为什么覆盖索引能够提升效率。

InnoDB索引模型

  • 在InnoDB中,表都是根据主键顺序以索引的形式存放的,这种存储方式的表称为索引组织表。又因为前面我们提到的,InnoDB使用了B+树索引模型,所以数据都是存储在B+树中的。

  • 每一个索引在InnoDB里面对应一棵B+树

 

主键索引和非主键索引的区别

  • 主键索引又叫聚簇索引 ,非主键索引又叫普通索引,那么这两种索引有什么区别呢?

  • 主键索引的叶子节点存放的是整行数据,非主键索引的叶子节点存放的是主键的值。

  • 假设有一张User表(id,age,name,address),其中有id和age两个字段,其中id是主键,age是普通索引,有几行数据u1-u5的(id,age)的值是(100,1)、(200,2)、(300,3)、(500,5)和(600,6) ,此时的两棵树的示例如下:

Mysql性能优化:为什么要用覆盖索引?

  • 从上图可以看出来,基于主键索引的树的叶子节点存放的是整行User数据,基于普通索引age的叶子节点存放的是id(主键)的值。

 

什么是回表?

  • 假设有一条查询语句如下:

  select * from user where age=3;

代码100分

  • 上面这条sql语句执行的过程如下:

    1、根据age这个普通索引在age索引树上搜索,得到主键id的值为300。

    2、因为age索引树并没有存储User的全部数据,因此需要根据在age索引树上查询到的主键id的值300再到id索引树搜索一次,查询到了u3。

    3、返回结果。

  • 上述执行的过程中,从age索引树再到id索引树的查询的过程叫做回表(回到主键索引树搜索的过程)。

  • 也就是说通过非主键索引的查询需要多扫描一棵索引树,因此需要尽量使用主键索引查询。

 

为什么使用覆盖索引?

  • 有了上述提及到的几个概念,便能很清楚的理解为什么覆盖索引能够提升查询效率了,因为少了一次回表的过程。

  • 假设我们使用覆盖索引查询,语句如下:

代码100分  select id from user where age=3;
  • 这条语句执行过程很简单,直接在age索引树中就能查询到id的值,不用再去id索引树中查找其他的数据,避免了回表。

 

总结

  • 覆盖索引的使用能够减少树的搜索次数,避免了回表,显著提升了查询性能,因此覆盖索引是一个常用的性能优化手段。

  • 留给读者一个问题:身份证是一个人的唯一识别凭证,如果有根据身份证号查询市民信息的需求,我们只要在身份证号字段上建立索引就够了。而再建立一个(身份证号、姓名)的联合索引,是不是浪费空间?

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/9310.html

(0)
上一篇 2023-02-11
下一篇 2023-02-11

相关推荐

  • MySQL 备份数据库[通俗易懂]

    MySQL 备份数据库[通俗易懂]原文:https://www.cnblogs.com/better-farther-world2099/articles/10276087.html …

    2023-03-31
    158
  • Druid 0.17 入门(2)—— 安装与部署[通俗易懂]

    Druid 0.17 入门(2)—— 安装与部署[通俗易懂]在Druid快速入门其实已经简单的介绍过最简化配置的单节点部署,本文我们将详细描述Druid的多种部署方式,对于测试开发环境可以选用轻量的单机部署方式,而生产环境我们最好选用集群部署的方式,确保系统的

    2023-01-29
    155
  • 在PyCharm中导入项目

    在PyCharm中导入项目PyCharm是一款流行的Python开发环境,可以帮助Python开发者提高开发效率和代码质量。在PyCharm中导入项目是一个必要的步骤,本文将详细介绍如何在PyCharm中导入项目。

    2024-05-26
    67
  • MySQL 数据库查询数据,过滤重复数据保留一条数据-

    MySQL 数据库查询数据,过滤重复数据保留一条数据-转自: http://www.maomao365.com/?p=10564 摘要: 下文讲述MySQL数据库查询重复数据时,只保留一条数据的方法 实现思路: 在MySQL数据库中没

    2022-12-19
    134
  • Python获取当前路径

    Python获取当前路径作为一名Python工程师,获取当前路径是日常工作中常常用到的操作。在Python中,获取当前路径有多种方法,本文将从多个方面对Python获取当前路径进行详细的阐述。

    2024-05-07
    72
  • Python饼图实现:统计数据可视化

    Python饼图实现:统计数据可视化随着数据的快速增长,数据可视化也成为了数据分析的重要手段之一。Python作为一种强大的编程语言,在数据分析领域也有着十分广泛的应用。饼图是一种常见的数据可视化图表,通过饼图可以直观地展示数据集的组成部分占比,也方便读者对数据进行理解和分析。

    2024-05-14
    72
  • Spark 两种方法计算分组取Top N[通俗易懂]

    Spark 两种方法计算分组取Top N[通俗易懂]Spark 分组取Top N运算 大数据处理中,对数据分组后,取TopN是非常常见的运算。 下面我们以一个例子来展示spark如何进行分组取Top的运算。 1、RDD方法分组取TopN from py

    2023-03-18
    145
  • 杭州哪里有开住宿费发票[通俗易懂]

    杭州哪里有开住宿费发票[通俗易懂]电薇13530507261 保-真,可-先-幵-验,陈经理。链接与装载是一个比较晦涩的话题,大家往往容易陷入复杂的细节中而难以看清问题的本来面目。从本质上讲各个系统的编译、链接、装载过程都是大同小异…

    2023-02-16
    148

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注