Mysql原理与调优-InnoDB行记录结构

news2025/1/9 19:01:26

目录

1.绪论

2.InnoDB的记录格式分类

3.compact格式

3.1 基本组成

3.2 记录额外信息

3.2.1 记录额外信息组成

3.2.2 变成字段长度列表

3.2.3 null值列表

3.2.4 记录头信息

3.3 实际记录

3.3.1 溢出页

3.3.2 varchar最多可以储存多少个字符的数据

4.其他记录格式和compact的不同


1.绪论

当我们插入的一条数据的时候,mysql为了做持久化,是将数据存储在磁盘中的。如果mysql每次只查询一条数据,这样效率太低。所以mysql每次从磁盘中读取数据是以页为单位的,每页大小为16kb。而一页数据包含多条记录,接下来我们来看看Mysql中记录是如何存储的。我们这里以如下这个sql举例:

2.InnoDB的记录格式分类

innodb有4种存储记录的格式,分别是redundant,compact,dynamic和compress。其中,redundant格式是5.0之间的一种格式,现在基本上已经弃用。Mysql5.7中默认的行记录格式是dynamic,dynamic和compress与compact的格式相似。所以,这里主要介绍一下compact的格式。

3.compact格式

3.1 基本组成

compact记录格式由3部分组成,分别是记录额外信息,隐藏列,实际数据。如下:

接下来我们来看看这3部分的内容:

3.2 记录额外信息

3.2.1 记录额外信息组成

记录额外信息由3部分组成,分别是变成字段列表,null值列表,记录头信息:

3.2.2 变成字段长度列表

1.用来记录该条记录里面的变成字段的长度,并且采用倒序排序。

2.如果某个字段不是变成长度,其长度不会出现在变长字段列表里面。

3.这里变成字段,指的不一定是varchar(n),text,blob这种字符长度是可以改变的字段,也可以是char(m)但是采用变长编码(比如UTF8:1-3个字节,UTF8mb4:1-4个字节)格式的字段。综上,变长字段指的是字节可变的字段。

举例如下:

注:这里为什么采用倒序排序呢?原因是在mysql的页中会有多条记录,每个记录通过记录头信息里面的next_record指针指向下一条记录,所以在遍历记录的时候,是首先获取到记录的next_record的位置。如果采用倒序排序,以next_record的位置向两边扩展,就能够得变长字段的长度和数据。

3.2.3 null值列表

1.在compact记录格式中,null值并没有占据存储空间,而是记录在null值列表中,如果该记录的额某列值为null,null值列表变为1,否者为0。

2.null值列表页采用和数据的倒序存储。

3.如果某个列一定不为null,便不会出现在null值列表中。

4.null值列表如果不是8位的倍数,高位补0。

3.2.4 记录头信息

记录头信息,包含40个字节,我们来看看有何作用。

名称大小描述
预留位11没使用
预留位21没使用
delete_mask1记录是否被删除,在页中的记录数据时采用懒删除的模式,每次删除会将该标志位设置为1
min_rec_mask1B+树非叶子节点的最小的一条记录,该索引设置为1
n_owned4

表示当前记录拥有的记录数,B+树每个节点可以存放多个元素,对于第一个元素,n_owned就是该节点后面的所有元素。所以该节点的阶为n_owned+1

heap_no4在记录堆中的位置信息,每页数据在插入的时候会采用顺序插入的方式,便是该条记录在整页中是第几条顺序
record_type3表示当前记录的类型,0表示普通记录,1表示B+树非叶子节点记录,2表示最小记录,3表示最大记录
next_record16执向下一条消息的指针

这里面最重要的一个属性就是next_record,通过它将记录堆中的索引从下到达组成一个链表。

3.3 实际记录

3.3.1 溢出页

前面说过,mysql存储数据的没页为16kb,即16384个字节,而且mysql要求每页至少存储2条记录,所以当记录超过16384个字节的时候,便会采用额外的页来记录数据,这种页计较溢出页。

3.3.2 varchar最多可以储存多少个字符的数据

mysql中要求,除了text和blob这种类型的数据外,其他类型总的长度(包括隐藏列和记录的额外信息)不能超过65534个字节。假设所采用的编码集占用的最大字节数为n(比如gbk为2,utf8为3),则最多占用的字符数为m=(65534-额外部分信息)/n。

4.其他记录格式和compact的不同

dynamic:dynamic主要在存储溢出页的时候,只存储溢出页的指针,没有存储该列的数据。

compress:compress会采用压缩算法对数据进行压缩。

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

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

相关文章

配置python的基本环境

python的背景知识 python是咋来的? Python 是一种广泛使用的高级编程语言,由 Guido van Rossum 在1989年底发明,第一个公开发行版发行于1991年。Python 的设计哲学强调代码的可读性和简洁的语法(尤其是使用空格缩进来区分代码块…

tcpdump使用指南

tcpdump 是一款强大的网络抓包工具,它使用 libpcap 库来抓取网络数据包,这个库在几乎在所有的 Linux/Unix 中都有。 tcpdump src 10.5.2.3 and dst port 3389 # 1. 基于IP地址过滤 # 根据源ip进行过滤 $ tcpdump -i eth2 src 192.168.10.100# 根据目标…

sqli-labs靶场练习(1、5-8关)

自己搭建环境啊喂...http://127.0.0.1/sqli-labs-php7-master/ 第一关 1.单引号判断是否存在注入点 /?id1 2.查询列数 ?id1 order by 3-- ?id1 order by 4-- 由此可判断有3列 3.查询用户名和密码分别在哪列 ?id-1 union select 1,2,3 -- 4.查询数据库名称为security ?…

CC2530组网实验-1

1,ZigBee协议栈 协议是一系列的通信标准,通信双方需要共同按照这一标准进行正常的数据发射和接收。协议栈是协议的具体实现形式,通俗点来理解就是协议栈是协议和用户之间的一个接口,开发人员通过使用协议栈来使用这个协议的&…

生活一地猫毛,空气还有猫浮毛!宠物空气净化器帮你消除这些烦恼

随着换毛季节的到来,铲屎官们如临大敌,猫咪将它们的毛发洒满每一个角落,仿佛室内下起了毛茸茸的飘雪。对于铲屎官来说,这不仅耗费时间的清理任务,更是一场守护健康的保卫战。为此,采取了许多措施来应对猫咪…

STL中的vector以及简单实现

vector的简单介绍&#xff1a; 头文件&#xff1a; #include<vector> vector是属于STL的一员&#xff0c;虽然vector的英文意思是向量&#xff0c;但是vector就是一个顺序表&#xff1b; 对于vector来说&#xff0c;面对string的设计的复杂和冗余&#xff0c;vector就…

Java毕业设计 基于SSM和Vue的图书馆座位预约系统小程序

Java毕业设计 基于SSM和Vue的图书馆座位预约系统小程序 这篇博文将介绍一个基于SSM框架和Vue开发的图书馆座位预约系统微信小程序&#xff0c;适合用于Java毕业设计。 功能介绍 用户 登录 注册 首页 图片轮播 关于我们 公告信息 图书馆信息 图书馆详情 预约选座 收藏 …

Tkinter Designer:拖拽式加速Python Tkinter GUI开发的神器

引言 在Python的世界里&#xff0c;创建美观且功能强大的图形用户界面&#xff08;GUI&#xff09;向来是开发者的挑战之一。Tkinter&#xff0c;作为Python的内置GUI库&#xff0c;虽然功能强大&#xff0c;但在实际使用中&#xff0c;设计和实现GUI的过程往往耗时且繁琐。Tki…

Linux中信号的处理

进程正在递达某一个信号期间&#xff0c;同类型的信号无法被递达&#xff01;&#xff01;&#xff01; 当当前信号正在被捕捉事&#xff0c;系统会自动将当前信号加入到进程的信号屏蔽字&#xff08;block&#xff09;。 当信号完成捕捉动作&#xff0c;系统又会自动解除对该…

R语言BIOMOD2 及机器学习方法的物种分布模拟与案例分析

BIOMOD2是一个R软件包&#xff0c;用于构建和评估物种分布模型&#xff08;SDMs&#xff09;。它集成了多种统计和机器学习方法&#xff0c;如GLM、GAM、SVM等&#xff0c;允许用户预测和分析物种在不同环境条件下的地理分布。通过这种方式&#xff0c;BIOMOD帮助研究者评估气候…

Linux-理解shell

文章目录 5. 理解shell5.1 shell的类型5.2 交互shell和系统默认shell5.3 安装zsh shell程序5.4 shell的父子关系5.5 命令列表5.6 命令分组5.7 使用命令分组创建子shell5.8 子shell用法5.9 shell的非内建命令和内建命令5.9.1 非内建命令5.9.2 内建命令5.9.3 history和alias命令介…

Cornerstone加载本地Dicom文件第二弹 - Blob篇

&#x1f340; 引言 当我们刚接触Cornerstone或拿到一组Dicom文件时&#xff0c;如果没有ImageID和后台接口&#xff0c;可能只是想简单测试Cornerstone能否加载这些Dicom文件。在这种情况下&#xff0c;可以使用本地文件加载的方法。之前我们介绍了通过node启动服务器请求文件…

cuda pytorch安装详细教程 GPU版

1.先安装anaconda Anaconda 1.1这里用了最简单的方法&#xff0c;后面将pytorch直接安装到base配置下面了。 1.2下载安装&#xff0c;全部勾选。 一定添加文件夹到path中去&#xff0c;否则后面下载pytorch&#xff0c;无法传输。 1.3 通过cmd&#xff0c;输入conda --versio…

CSP-J 模拟题2

如果x大于45&#xff0c;则输出-1 设定一个整数now&#xff0c;他的初始值为9&#xff1b; 当x>now&#xff0c;就x-now&#xff0c;并且now--; 根据解析写代码1&#xff1a; #include <bits/stdc.h> using namespace std; int a[101010]; int main(){int x;cin>…

设计师必备网站,素材、灵感一手抓

设计师都在哪些地方找素材&#xff0c;找灵感&#xff1f;分享8个设计师必备网站&#xff0c;素材免费下载&#xff0c;还能看到很多国内外大神的设计之作&#xff0c;赶紧收藏起来吧~ 1、baotu 包图网_专注原创商用设计图片下载&#xff0c;会员免费设计素材模板独家图库 国内…

QChart笔记7:基于QPolarChart的雷达图、能力图

六边形战士这个词经常听说&#xff0c;用来描述这个词的是六边形雷达图/能力图。在网上搜索如何用QChart实现没有找到&#xff0c;于是就自己研究出一种写法。 先看看效果&#xff1a; 可以用这个图表示游戏中的人物属性&#xff0c;看看我的几个不太厉害的NPC。 在QT自带的实…

STL—容器—list【list的介绍和基本使用】【list的迭代器失效问题】

STL—容器—list list的使用并不难&#xff0c;有了之前使用string和vector的基础后&#xff0c;学习起来并不难。因此这里不在详细的讲解如何使用&#xff0c;而是大致的将其基本接口都熟悉一下 1.list介绍 list的文档介绍 list是可以在常数范围内在任意位置进行插入和删除…

解决App推广难题,Xinstall带你实现一键唤起,提升用户转化率!

在移动互联网时代&#xff0c;App的推广和运营成为了开发者们面临的一大挑战。如何让用户在各种场景下快速、便捷地唤起你的App&#xff0c;提升用户转化率和活跃度呢&#xff1f;今天&#xff0c;就让我们一起来了解一下Xinstall这一神奇的助手&#xff0c;它将如何解决这些痛…

基于YOLOv10和半监督学习的小麦麦穗检测算法:YOLOv10_ssod

基于YOLOv10和半监督学习的小麦麦穗检测算法&#xff1a;YOLOv10_ssod 1.引言2.数据集2.1 公共数据集2.2 自制数据集 3.YOLOv10算法及改进3.1 YOLOv10原版算法3.2 YOLOv10算法改进3.3 对比实验 4.半监督学习方法5.训练效果5.1最终检测效果5.2YOLOv10的精度曲线图5.3 半监督YOLO…

【Material-UI】Button 组件中的图标和标签按钮(Buttons with Icons and Label)详解

文章目录 一、基础用法1. 左侧图标&#xff08;startIcon&#xff09;2. 右侧图标&#xff08;endIcon&#xff09; 二、图标与标签的搭配三、高级用法和最佳实践1. 自定义图标2. 视觉一致性3. 动态图标 四、总结 在现代用户界面设计中&#xff0c;图标在提高用户体验&#xff…