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

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

相关推荐
莳花微语14 分钟前
使用MyCAT实现分布式MySQL双主架构
分布式·mysql·架构
he2581920 分钟前
centOS 7.9 安装JDK MYSQL
java·mysql·centos
夜泉_ly3 小时前
MySQL -安装与初识
数据库·mysql
qq_529835354 小时前
对计算机中缓存的理解和使用Redis作为缓存
数据库·redis·缓存
月光水岸New6 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6756 小时前
数据库基础1
数据库
我爱松子鱼6 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo7 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser7 小时前
【SQL】多表查询案例
数据库·sql
Galeoto8 小时前
how to export a table in sqlite, and import into another
数据库·sqlite