MySql中什么是回表? 如何减少回表的次数

背景

在InnerDB中, B+数的叶子节点存储数据的索引是聚集索引,也就是我们说的主键索引,而B+数的叶子节点存储主键索引的是非聚集索引,也就是其他的索引 普通索引 唯一索引 组合索引,也就是非主键索引,在InnerDB中 主键索引就是他的叶子节点上面存储着我们想要的这一行数据,而非主键索引则存在着是主键索引的值

什么是回表?

所谓的回表,就是指的是我们根据非主键索引,找到主键的值,再根据主键的值, 找到该索引上对应的叶子节点的值, 这个过程我们称之为回表,其实也很好理解

再INNERDB中, 我们使用的主键索引查询的时候效率更高, 因为直接拿到对应这一行的数据, 不需要回表,比如索引覆盖和索引下推技术, 也可以减少回表的次数

什么是索引下推和索引覆盖

首先我们创建一个组合索引

create index indextest on tablename key1 key2 key 3

索引下推 :查询过程中,比如我们有一个组合索引

首先mysql会先查询到key1=123的列, 再根据这些列返回对应的key2和key3符合条件的值进行筛选

sql 复制代码
        select  字段  from tablename where key1=123  and key2="%***"  and key3="%****"

索引覆盖:在查询的过程中, 查询的值就在组合索引上,不需要回表,索引称之为覆盖索引,不需要从数据表中获取

sql 复制代码
        select key2 from tablename where key1=111

以上就是我们今天分享的内容, 如有帮助,请不要吝啬咱们的赞哦 感谢大家

相关推荐
小吴编程之路3 分钟前
MySQL 索引核心特性深度解析:从底层原理到实操应用
数据库·mysql
~莫子13 分钟前
MySQL集群技术
数据库·mysql
凤山老林23 分钟前
SpringBoot 使用 H2 文本数据库构建轻量级应用
java·数据库·spring boot·后端
就不掉头发32 分钟前
Linux与数据库进阶
数据库
与衫35 分钟前
Gudu SQL Omni 技术深度解析
数据库·sql
咖啡の猫1 小时前
Redis桌面客户端
数据库·redis·缓存
oradh1 小时前
Oracle 11g数据库软件和数据库静默安装
数据库·oracle
what丶k1 小时前
如何保证 Redis 与 MySQL 数据一致性?后端必备实践指南
数据库·redis·mysql
_半夏曲1 小时前
PostgreSQL 13、14、15 区别
数据库·postgresql
把你毕设抢过来1 小时前
基于Spring Boot的社区智慧养老监护管理平台(源码+文档)
数据库·spring boot·后端