通过与 Jira 对比,让您更全面了解 PingCode

  • 首页
  • 需求与产品管理
  • 项目管理
  • 测试与缺陷管理
  • 知识管理
  • 效能度量
        • 更多产品

          客户为中心的产品管理工具

          专业的软件研发项目管理工具

          简单易用的团队知识库管理

          可量化的研发效能度量工具

          测试用例维护与计划执行

          以团队为中心的协作沟通

          研发工作流自动化工具

          账号认证与安全管理工具

          Why PingCode
          为什么选择 PingCode ?

          6000+企业信赖之选,为研发团队降本增效

        • 行业解决方案
          先进制造(即将上线)
        • 解决方案1
        • 解决方案2
  • Jira替代方案

25人以下免费

目录

在Mysql中,什么是回表,什么是覆盖索引,索引下推

在MySQL中,回表:当使用非聚集索引进行查询时,MySQL需要根据该索引的键值去聚集索引中查找对应的数据行的过程。覆盖索引:在查询语句中,所需的数据都可以从索引中获取,而不需要再去聚集索引中查找。索引下推:MySQL 5.6版本引入的一项优化技术。它允许在非聚集索引中进行更多的过滤操作,减少回表次数。

一、在Mysql中,回表是什么

在MySQL中,回表(Index Lookups)是指在使用非聚集索引(Secondary Index)进行查询时,MySQL需要根据该索引的键值去聚集索引(Primary Index)中查找对应的数据行的过程。

举例来说,假设有一个包含姓名和年龄的表,并在姓名字段上创建了非聚集索引。当使用姓名索引进行查询时,MySQL会首先在该索引中定位到满足条件的记录的主键值,然后再根据这些主键值去聚集索引(通常是主键索引)中查找对应的数据行。这个额外的查找聚集索引的过程就是回表。

回表操作可能导致额外的IO开销,影响查询性能,特别是当查询的列不包含在非聚集索引中时。为了优化查询性能,可以使用覆盖索引(Covering Index)和索引下推(Index Condition Pushdown)技术来避免回表操作,提高查询效率。

二、什么是覆盖索引,索引下推

覆盖索引是指在查询语句中,所需的数据都可以从索引中获取,而不需要再去聚集索引中查找。这样就避免了回表操作,从而提高了查询性能。当查询的列都包含在索引中时,MySQL可以直接从索引中获取数据,无需再访问聚集索引。

例如,对于上面的例子,如果查询语句只需要获取姓名字段的值,而姓名字段在姓名索引中已经包含,那么MySQL可以直接从姓名索引中获取数据,而无需回表查找。

索引下推是MySQL 5.6版本引入的一项优化技术。它允许在非聚集索引中进行更多的过滤操作,减少回表次数。索引下推将查询过滤条件下推到非聚集索引层级,只有符合过滤条件的行才会去查找聚集索引。

例如,对于上面的例子,如果查询语句既需要获取姓名字段的值,又需要获取年龄字段的值,并且同时有姓名和年龄的索引,那么MySQL可以在姓名索引层级先过滤出符合姓名条件的记录,然后再根据年龄条件去聚集索引中查找对应的数据行。这样就减少了回表的次数,提高了查询性能。

延伸阅读

回表会造成什么

  1. 性能下降:回表操作涉及额外的IO操作,需要访问聚集索引来获取完整的数据行,导致查询性能下降。特别是在大规模数据表上或高并发的查询场景下,回表操作可能会成为性能瓶颈。
  2. 增加数据库负载:回表操作会引起额外的数据库负载,包括磁盘读取和内存消耗。当频繁进行回表操作时,可能会导致数据库服务器的负载过高,影响整体性能。
  3. 降低查询效率:由于回表需要额外的IO访问,查询的速度变慢,从而降低了查询效率,影响了用户体验。
  4. 增加网络开销:如果数据库服务器和应用服务器位于不同的节点或机器上,回表操作会增加网络开销,进一步影响查询性能。
相关文章