什么是回表查询

"回表查询"是 数据库索引使用中的一个概念 ,尤其常见于 MySQL InnoDB 存储引擎


1️⃣ 回表查询的定义

回表查询(Index Lookup + Table Access / Bookmark Lookup)

指查询时使用了 非覆盖索引(non-covering index),索引本身没有包含查询需要的全部列,需要通过索引找到主键或行指针,然后再回到聚簇索引(或者数据表)去读取完整行数据的过程。

简单来说:

  1. 先在索引中找到匹配的键值和对应的行指针(主键)。
  2. 再根据主键去 表(叶子节点) 找完整的行数据。

2️⃣ 举例说明

假设有一张表 user

sql 复制代码
CREATE TABLE user (
    id INT PRIMARY KEY,
    name VARCHAR(20),
    age INT,
    INDEX idx_name(name)
);
  • idx_name 索引只包含 nameid(因为是二级索引,InnoDB 二级索引里存的是索引列 + 主键)。
  • 查询:
sql 复制代码
SELECT age FROM user WHERE name = 'Alice';
  • 索引 idx_name 里有 name='Alice' 对应的 id=101

  • 但是我们要查询的列是 age,索引里没有。

  • 回表步骤

    1. idx_name 索引中找到 name='Alice'id=101
    2. 再用 id=101 去聚簇索引(表)中找到 age 列的值。
  • 这个额外的访问表的过程,就是 回表查询


3️⃣ 回表查询的特点

  • 触发条件:非覆盖索引、查询列不在索引中。

  • 开销:会多一次访问表(磁盘 I/O 或 Buffer Pool)。

  • 优化方式

    1. 覆盖索引:在索引里包含查询的所有列。

      sql 复制代码
      CREATE INDEX idx_name_age ON user(name, age);

      这样查询 SELECT age FROM user WHERE name='Alice'; 就不需要回表。

    2. 尽量使用主键查询,避免二级索引回表。

    3. 查询时只选索引列,减少回表。


💡 总结一句话:

回表查询就是:先用二级索引找到主键,再用主键去表里获取完整行数据的过程。


相关推荐
草莓熊Lotso2 小时前
MySQL 事务管理全解:从 ACID 特性、隔离级别到 MVCC 底层原理
linux·运维·服务器·c语言·数据库·c++·mysql
不愿透露姓名的大鹏2 小时前
MySQL InnoDB核心参数深度优化/性能调优
运维·服务器·数据库·mysql
零陵上将军_xdr3 小时前
MySQL体系架构
数据库·mysql·架构
柒.梧.3 小时前
MySQL索引优化+慢查询全解析
数据库·mysql
captain3763 小时前
数据库约束
mysql
呆瑜nuage3 小时前
MySQL数据类型全解析
数据库·mysql
Harvy_没救了3 小时前
MySQL主从架构深度解析:原理、优化与实践指南
运维·mysql·架构
黑牛儿4 小时前
MySQL 实战进阶:从单表优化到分布式数据库适配
数据库·分布式·mysql
momin~4 小时前
MySQL-part3【数据库约束、表设计】
数据库·mysql