MySQL回表

news2025/1/23 4:10:54

1.索引结构

1.1.B-Tree(B树)和B+Tree(B+树)

在这里插入图片描述
在这里插入图片描述

前面是B-Tree,后面是B+Tree,两者的区别在于:

  • B-Tree中,所有的节点都会带有指向具体记录的指针;B+Tree中只有叶子节点才会带有指向具体记录的指针;
  • B-Tree中,不同的叶子之间没有连在一起;B+Tree中所有的叶子节点通过指针连接在一起;
  • B-Tree中,可能在非叶子节点就拿到了指向具体记录的指针,搜索效率不稳定;B+Tree中,一定要到叶子节点才可以获取到指向具体记录的指针,搜索效率稳定;

基于上述几点分析,可以得出如下结论:

  • B+Tree中,由于非叶子节点不带有指向具体记录的指针,所以非叶子节点中可以存放更多的索引项,这样就可以有效降低树的高度,进而提高搜索的效率;

  • B+Tree中,叶子节点通过指针连接在一起,这样如果有范围扫描的需求,那么实现起来非常容易,而对于B-Tree,范围扫描则需要不停的在叶子节点和非叶子节点之间移动;

一棵B+Tree到底可以存放多少条数据呢?以主键索引的B+Tree为例(二级索引存储数据量的计算原理类似,但是叶子节点和非叶子节点上存储的数据格式略有差异),我们可以简单算一下:

①.计算机在存储数据的时候,最小的存储单元是扇区,一个扇区的大小是512字节,而文件系统(例如XFS,EXT4)最小单元是块,一个块的大小是4KB.INNODB引擎存储数据的时候,是以页为单位的,每个数据页的大小默认是16KB,即四个块;

②.假设数据库中一条记录是1KB,那么一个页就可以存放16条数据(叶子结点);对于非叶子节点存储的则是主键值+指针,在InnoDB中,一个指针的大小是6个字节,假设我们的主键是bigint,那么主键占8个字节(当然还有其他一些头信息也会占用字节我们这里就不考虑了),大概算一下:

16*1024/(8+6) = 1170

一个非叶子节点可以指向1170个页,那么一个三层的B+Tree可以存储的数据量为:

1170*1170*16 = 21902400 //可以存放2100万条数据

③.在InnoDB存储引擎中,B+Tree的高度一般为2-4层,这就可以满足千万级数据的存储,查找数据的时候,一次页的查找代表一次IO,那我们通过主键索引查询的时候,其实最多只需要2-4次IO操作就可以了;

2.两类索引

1.MySQL中的索引有很多种不同的分类方式,可以按照数据结构分,可以按照逻辑角度分,也可以按照物理存储分,其中按照物理存储方式,可以分为聚簇索引和非聚簇索引;

2.我们日常所说的主键索引,其实就是聚簇索引(Clustered Index);主键索引之外,其他的都是称之为非主键索引,非主键索引也被称为二级索引(Secondary Index),或者叫辅助索引;

3.对于主键索引和非主键索引,使用的数据结构都是B+Tree,唯一的区别在于叶子节点中存储的内容不同(最大的区别):

①.主键索引的叶子节点存储的是一行完整的数据;

②.非主键索引的叶子节点存储的则是主键值;

4.当我们进行查询的时候:

①.如果是通过主键索引来查询数据,例如"select * from user where id = 100",那么此时只需要搜索主键索引的B+Tree就可以找到数据;

②.如果是通过非主键索引来查询数据,例如"select * from user where username=‘zhangsan’",那么此时需要先搜索username这一列索引的B+Tree,搜索完成之后得到主键值,然后再去搜索主键索引的B+Tree,才可以取到一行完整的数据;

对于第二种查询方式而言,一共搜索了两棵B+Tree,第一次搜索非主键索引B+Tree,获取主键值之后再去搜索主键索引的B+Tree,这个过程就是所谓的回表;

3.一定会回表吗?

1.如果不使用主键索引就一定需要回表吗?

不一定!

2.如果查询的列本身就存在于索引中,那么即使使用二级索引,一样也是不需要回表的;

3.1.例子:

①.表结构如下:
在这里插入图片描述

如上图,uname和address字段组成一个复合索引,那么此时虽然这是一个二级索引,但是索引树的叶子节点中除了保存主键值,也保存了address和uname的值;

使用非主键字段查询数据,查看执行计划:
在这里插入图片描述

可以看到,此时使用到了uname作为查询条件,但是最后的extra的值为Using index,这就表示用到了索引覆盖扫描(覆盖索引),此时直接从索引中过滤不需要的记录并返回命中的结果,这一步是在MySQL服务层完成的,并不需要回表;

4.扩展: 为什么要在数据库中建议使用自增主键?

1>.自增主键往往占用空间比较小,int占4个字节,bigint占8个字节.由于二级索引的叶子节点存储的就是主键值,所以如果主键占用空间小,意味着二级索引的叶子节点将来占用的空间小(间接降低B+Tree的高度,一提高搜索效率);

2>.自增主键插入的时候比较快,直接插入即可,不会涉及到叶子节点分裂等问题(不需要挪动其他记录).而其他非自增主键插入的时候,可能要插入到两个已有的数据中间,就有可能导致叶子节点分裂等问题,插入效率低(要挪动其他记录);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/71883.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java版商城之 Spring Cloud+SpringBoot+mybatis+uniapp b2b2c o2o 多商家入驻商城 直播带货商城 电子商务

一个好的SpringCloudSpringBoot b2b2c 电子商务平台涉及哪些技术、运营方案?以下是我结合公司的产品做的总结,希望可以帮助到大家! 搜索体验小程序:海哇 1. 涉及平台 平台管理、商家端(PC端、手机端)、买…

浴室预约小程序毕业设计,洗澡预约澡堂预约系统设计与实现,微信小程序毕业设计论文怎么写毕设源码开题报告需求分析怎么做

项目背景和意义 目的:本课题主要目标是设计并能够实现一个基于微信小程序浴室预约系统,前台用户使用小程序,后台管理使用JavaMysql开发,后台使用了springboot框架;通过后台添加设定浴室类型、录入浴室和管理浴室、管理…

CTPN+CRNN算法端到端实现文字识别的实战开发

本文分享自华为云社区《CTPNCRNN 算法端到端实现文字识别》,作者:HWCloudAI。 OCR介绍 光学字符识别(英语:Optical Character Recognition,OCR)是指对文本资料的图像文件进行分析识别处理,获取…

Java规则引擎Drools急速入门

文章目录1.Drools规则引擎简介2.Drools API开发步骤3.SpringBoot整合Drools案例4.Drools基础语法5.Drools条件语法部分6.Drools结果操作部分7.Drools内置属性部分8.Drools高级语法部分1.Drools规则引擎简介 (1)什么是规则引擎 ​ 全称为业务规则管理系…

类与对象(上篇)

类与对象面向过程和面向对象类的引入类的定义类的访问限定符及封装访问限定符封装类的作用域类的实例化类对象类对象的存储方式类成员函数的this指针this指针的引出this指针的特性面向过程和面向对象 C语言是面向过程,注重的是过程,先分析求解问题的步骤…

【计算机视觉】目标检测中Faster R-CNN、R-FCN、YOLO、SSD等算法的讲解(图文解释 超详细必看)

觉得有帮助请点赞关注收藏~~~ 一、基于候选区域的目标检测算法 基于候选区域的深度卷积神经网络(Region-based Convolutional Neural Networks)是一种将深度卷积神经网络和区域推荐相结合的物体检测方法,也可以叫做两阶段目标检测算法。第一…

Web大学生网页作业成品——环保垃圾分类网站设计与实现(HTML+CSS+JavaScript) web前端开发技术 web课程设计 网页规划与设计

🎀 精彩专栏推荐👇🏻👇🏻👇🏻 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业…

RFID标签让企业海量固定资产实现科学化管理

近年来,随着物联网、IoT、移动技术、云计算技术的成熟,越来越多的企业开始使用RFID标签管理企业海量的固定资产。优化固定资产标准化管理流程,有效管理和库存固定资产,进一步提高企业实物资产管理和库存效率。 包括资产申购、验收…

【操作系统】计算机大脑CPU

1.CPU组成机构和存储器层级 (1)CPU是计算机硬件系统的核心部件-大脑 结构:运算器控制器(两个部件里面有寄存器组)通过CPU内部的总线进行通信 (2)单核CPU架构 控制器Control Unit简称【CU】 …

Python使用Opencv图像处理方法完成手势识别(二)

Opencv完成手势识别根据坐标识别寻找最低点计算其他点与最低点的距离通过距离阈值判断手指根数和手势效果展现完整代码当我们把手近似出来后会得到一组轮廓的点坐标,我自己手势识别的思路就是根据点坐标来判断手势。根据坐标识别 寻找最低点 所谓寻找最低点&#…

浅谈Nacos注册中心集群分布式架构设计

前言 Nacos的压测性能是非常好的,这里是Nacos官方的压测报告。3节点(CPU 16核,内存32G)规模集群,压测容量服务数可达60W,实例注册数达110W,集群运行持续稳定,达到预期;注册/查询实例TPS达到 13…

ModStartBlog v6.3.0 任务调度重构,UEditor 升级

系统介绍 ModStart 是一个基于 Laravel 模块化极速开发框架。模块市场拥有丰富的功能应用,支持后台一键快速安装,让开发者能快的实现业务功能开发。 系统完全开源,基于 Apache 2.0 开源协议。 功能特性 丰富的模块市场,后台一键…

跨设备链路聚合 M-LAG

M-LAG(Multichassis Link Aggregation Group)即跨设备链路聚合组,是一种实现跨设备链路聚合的机制,如下图所示,将SwitchA和SwitchB通过peer-link链路连接并以同一个状态和Switch进行链路聚合协商,从而把链路…

学校介绍静态HTML网页设计作品 DIV布局学校官网模板代码 DW大学网站制作成品下载 HTML5期末大作业

🎉精彩专栏推荐 💭文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业: 【📚毕设项目精品实战案例 (10…

iOS app上架app store流程详解​

前提条件​ 在有效期内的苹果开发者账号(类型为个人或者公司账号)。还有一种情况,就是你的Apple ID被添加到公司开发者账号团队里面,这样也是可以的,但是需要叫管理员给你开通相应的账号权限,如下截图&…

[附源码]Python计算机毕业设计Django在线图书销售系统

项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等。 环境需要 1.运行环境:最好是python3.7.7,我…

Vue | 有关Vue2路由知识点的一些总结,以及Vue3路由做出了哪些调整?

目录 Vue2: 1. 路由: 2. 路由规则: 3. 实现切换(active-class可配置高亮样式) 4. 指定展示位置 5. 路由的query参数 6. params传参: 7. 多级路由 8. 路由的props配置 9. 的replace属性 10. 编…

Android databinding之BindingMethod与BindingMethods介绍与使用(五)

一、介绍 前面几篇文章已介绍了很多data binding的用法,今天我将会介绍一个新的方法绑定BindingMethod的用法。 BindingMethod,从名字可以看出是绑定方法的,绑定的一般都是和布局有关,通过绑定来提高布局可扩展性。 二、使用 Bin…

把盏言欢,款款而谈,ChatGPT结合钉钉机器人(outgoing回调)打造人工智能群聊/单聊场景,基于Python3.10

就像黑火药时代里突然诞生的核弹一样,OpenAI的ChatGPT语言模型的横空出世,是人工智能技术发展史上的一个重要里程碑。这是一款无与伦比、超凡绝伦的模型,能够进行自然语言推理和对话,并且具有出色的语言生成能力。 好吧&#xff…

资产扫描神器ARL增强改造

拉取项目首先从GitHub克隆到服务器上。git clone https://github.com/ki9mu/ARL-plus-docker/修改配置文件因为ARL在配置文件里设置了黑名单,有时候项目为GOV或者EDU之类的时候无法进行扫描,所以在这里修改一下配置文件就可以解除限制。cd ARL-plus-dock…