什么是回表查询

"回表查询"是 数据库索引使用中的一个概念 ,尤其常见于 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. 查询时只选索引列,减少回表。


💡 总结一句话:

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


相关推荐
rising start14 分钟前
三、深入理解MySQL索引底层
数据库·mysql
UtopianCoding25 分钟前
数据库语法对比详细规则
数据库·mysql·gaussdb
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ34 分钟前
MySQL选择字符集和排序规则
数据库·mysql
努力努力再努力wz34 分钟前
【QT入门系列】QWidget 六大常用属性详解:windowOpacity、cursor、font、focus、toolTip 与 styleSheet
android·开发语言·数据结构·c++·qt·mysql·算法
周易宅44 分钟前
Docker MySQL 8.0.45 性能优化配置文档
mysql·docker·性能优化
一条泥憨鱼1 小时前
深入理解 MySQL 索引:原理、分类与优化实战
数据库·mysql
一条泥憨鱼1 小时前
详解MySQL事务(超详细版)
java·数据库·mysql·spring·maven·后端开发
j7~1 小时前
【MYSQL】 数据库的常见数据类型--详解
数据库·mysql·decimal·varchar·数据库的基本类型
rising start10 小时前
二、全面理解MySQL架构
mysql·架构
bqq1986102611 小时前
MySQL性能优化
mysql·mysql优化