mysql-Innodb记录结构深度解析

Innodb记录结构

      • InnoDB记录结构深度解析
        • 一、InnoDB存储基础单元:页(Page)
        • 二、行格式(Row Format)
      • 三、核心行格式详解
        • 1. Compact行格式
          • 结构组成:
        • 2. Redundant行格式(兼容旧版本)
          • 核心差异:
        • 3. Dynamic与Compressed行格式
        • **适用场景差异**
      • 四、行溢出处理机制
      • 五、关键对比与选型建议
      • 六、总结

InnoDB记录结构深度解析

一、InnoDB存储基础单元:页(Page)
  • 页大小:默认16KB,是InnoDB磁盘与内存交互的基本单位。

  • 页作用:所有数据读写操作以页为单位,避免频繁磁盘IO,提升性能。

二、行格式(Row Format)

InnoDB提供4种行格式:CompactRedundantDynamicCompressed。核心区别在于数据存储方式和溢出处理机制。


三、核心行格式详解

1. Compact行格式

在这里插入图片描述

结构组成:
  1. 变长字段长度列表(Variable-Length Field Length List)

    1. 逆序存储:所有变长字段(如VARCHAR)的真实数据长度按列顺序逆序存放。

    2. 长度表示规则

  • 若最大长度 ≤ 255字节,用1字节表示实际长度。

  • 若最大长度 > 255字节,根据实际长度选择1或2字节(L≤127用1字节,L>127用2字节)。

  1. NULL值列表(NULL Value List)

    1. 二进制位图:每个允许NULL的列对应1位(1表示NULL,0非NULL),按列逆序排列。

    2. 字节对齐:不足8位补0,例如3个NULL列用1字节(二进制高位补0)。

  2. 记录头信息(Record Header)

    1. 固定5字节,关键标志位:
  • delete_mask:标记记录是否被删除。

  • next_record:下一条记录的相对位置(链表结构)。

  • record_type:记录类型(0-普通,1-B+树非叶节点,2-最小记录,3-最大记录)。

  1. 真实数据(Real Data)

    1. 隐藏列:自动添加row_id(可选)、transaction_id(事务ID)、roll_pointer(回滚指针)。

    2. CHAR(M)存储

  • 定长字符集(如ascii):固定占用M×字符字节,不足填充空格。

  • 变长字符集(如utf8):长度存入变长字段列表,至少占用M字节。

相比redundant的改进:

  • Compact仅存储非NULL变长字段的实际字节长度(逆序排列),redundant存储所有字段偏移地址

  • Compact使用位图标记NULL列(每列1位),例如3个允许NULL的列仅需1字节存储状态。Redundant则通过偏移量高位标记NULL,每个允许NULL的列需额外占用偏移量空间

  • Compact头信息5字节 包含delete_maskrecord_type等核心字段,支持更细粒度的记录管理。redundant头信息6字节,额外包含n_field(列数量)和1byte_offs_flag(偏移量字节数标识),缺少record_type字段

  • 发生行溢出:Compact保留768字节前缀,redundant无优化机制直接存额外页导致更多空间碎片


2. Redundant行格式(兼容旧版本)

在这里插入图片描述

核心差异:
  • 字段长度偏移列表:所有列(含隐藏列)的结束位置偏移量,逆序存储,通过差值计算列长。

  • NULL处理:偏移量首比特标记NULL,定长列NULL仍占空间(填充0x00),变长列不占。

  • 记录头信息

    • 6字节,含n_field(列数量)和1byte_offs_flag(偏移量字节数标记)。

    • record_type字段。


3. Dynamic与Compressed行格式
  • Dynamic:类似Compact,但所有溢出数据存于溢出页,仅保留20字节指针。

  • Compressed:在Dynamic基础上增加页级压缩,减少存储空间。

适用场景差异
  • Dynamic的优势场景

    • 适用于超长变长字段(如TEXT/BLOB),溢出数据占比高时,减少原始页空间浪费。

    • 不适用场景:若记录长度普遍小于页容量(16KB),Dynamic与Compact性能差异不大。

  • Compressed的优势场景

    • 适合存储成本敏感、读多写少的场景(如日志归档、历史数据存储)。

    • 不适用场景:OLTP系统(高频更新)、或CPU资源紧张时,压缩开销可能成为瓶颈。


四、行溢出处理机制

  • 溢出条件:单行数据超过页大小(16KB)阈值(约768字节后存溢出页)。

  • 溢出页管理

    • 仅保留前缀数据(768字节)在本页,剩余数据存入溢出页。

    • 通过指针链接溢出页,保证主页数据连续性。


五、关键对比与选型建议

特性CompactRedundantDynamic
变长字段存储仅变长字段长度列表全字段偏移列表类似Compact
NULL处理独立NULL列表偏移量首比特标记同Compact
溢出处理部分保留前缀同Compact全部存溢出页
空间效率较低
适用场景常规OLTP旧系统兼容大字段频繁更新

格式适用场景不适用场景
Compact通用场景,短记录为主,兼容旧版本大字段频繁访问,存储成本敏感
Dynamic超长变长字段(TEXT/BLOB),溢出数据占比高记录普遍短小,需避免溢出页I/O开销
Compressed读多写少,存储成本敏感(如归档数据)高频写入、CPU资源紧张、OLTP系统

六、总结

  1. 行格式选择:默认使用Dynamic(MySQL 5.7+),平衡空间与性能。

  2. CHAR vs VARCHAR

    1. CHAR适合定长数据(如MD5),减少碎片。

    2. VARCHAR节省空间,但频繁更新可能产生碎片。

  3. 避免行溢出:大字段(如TEXT/BLOB)建议分离存储或使用压缩。

  4. NULL优化:尽量使用NOT NULL,减少NULL列表开销。

通过理解InnoDB记录结构,可针对性优化表设计,提升存储效率与查询性能。

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

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

相关文章

Deepin(Linux)安装MySQL指南

1.下载 地址:https://downloads.mysql.com/archives/community/ 2.将文件解压到 /usr/local 目录下 先cd到安装文件所在目录再解压,本机是cd /home/lu01/Downloads sudo tar -xvJf mysql-9.2.0-linux-glibc2.28-x86_64.tar.xz -C /usr/local3.创建软链…

ZT9 游游的字母翻倍

描述 游游拿到了一个长度为n的字符串,她每次操作会选择一个区间[l,r],将第l个字母到第r个字母各重复一次,插入到该字母的后面。 例如,对于字符串"abcd",若选择区间[2,3]进行操作,字符串将变成&qu…

Visual Studio更新说明(关注:.NET+AI生产力)

Ver V0.0:Visual Studio 2022 v17.12更新:.NET9AI生产力 AI插件推荐 (1)腾讯云AI代码手(内含了DeepSeek-R1),目前免费,但收费我也可能会买。 AI插件!推荐 (1)百度的…

C++ 设计模式-访问者模式

C++访问者模式 一、模式痛点:当if-else成为维护噩梦 开发动物园管理系统,最初的需求很简单: class Animal {}; class Cat : public Animal {}; class Dog : public Animal {};// 处理动物叫声 void makeSound(Animal* a) {if (auto c = dynamic_cast<Cat*>(a)) {st…

QEMU源码全解析 —— 内存虚拟化(17)

接前一篇文章:QEMU源码全解析 —— 内存虚拟化(16) 本文内容参考: 《趣谈Linux操作系统》 —— 刘超,极客时间 《QEMU/KVM源码解析与应用》 —— 李强,机械工业出版社 QEMU内存管理模型

java基于数组实现队列(四)

概述 实现我上一篇博客中提到的 实际上&#xff0c;就是用synchronized代码块解决线程安全问题&#xff0c;以及利用wait()、notify()实现线程阻塞、唤醒。 实现 pollV3() private Object lockBySynchronizednew Object();public int pollV3() {synchronized (lockBySynchr…

linux -对文件描述符的操作dup、fcntl有五种

dup #include<unistd.h> int dup(int oldfd);作用&#xff1a;复制一个新的文件描述符fd 3, int fd1 dup(fd);f指向的是a.txt,fd1指向的也是a.txt从空闲的文件描述符表中找一个最小的作为新的拷贝的文件描述符返回&#xff1a;成功返回新的文件描述符&#xff0c;失败…

DeepSeek各模型现有版本对比分析

文章目录 一、基础模型系列&#xff1a;V1 到 V3 的演进二、专用模型系列&#xff1a;推理与多模态三、版本选型与商业化趋势 DeepSeek作为最近特别火爆的模型&#xff0c;本文将对DeepSeek现有的主要版本进行对比分析,涵盖参数规模、训练数据、功能改进、应用场景和性能表现等…

深入解析:在Spring Boot中集成MyBatis Plus实现高效数据库操作

前后端微服务商城项目&#xff0c;手把手教学&#xff01; 在Spring Boot中集成第三方框架&#xff0c;实际上是非常常见的一种做法。Spring Boot自带了很多开箱即用的功能&#xff0c;但在实际项目开发中&#xff0c;我们经常需要借助一些第三方框架来实现更为复杂的功能。比如…

现场可以通过手机或者pad实时拍照上传到大屏幕的照片墙现场大屏电子照片墙功能

现场可以通过手机或者pad实时拍照上传到大屏幕的照片墙现场大屏电子照片墙功能&#xff0c;每个人都可以通过手机实时拍照上传到大屏幕上,同时还可以发布留言内容&#xff0c;屏幕上会同步滚动播放展示所有人的照片和留言。相比校传统的照片直播功能更加灵活方便&#xff0c;而…

项目管理工具Jira在营销工作管理中的应用与实践

本文由Atlassian全球白金合作伙伴-龙智编辑整理。 市场营销人员是维系组织团结的粘合剂。作为公司中最具协作精神的团队之一&#xff0c;他们确保每个人目标一致&#xff0c;并专注于客户真正的需求。他们擅长沟通协作&#xff0c;积极响应客户诉求及塑造品牌方向&#xff0c;…

grafana 忘记登陆密码

重置 Grafana 登录密码 通过命令行重置 admin 密码 # 如果是通过二进制安装的 Grafana grafana-cli admin reset-admin-password <新密码>

基于Flask框架的食谱数据可视化分析系统的设计与实现

【Flask】基于Flask框架的食谱数据可视化分析系统的设计与实现 &#xff08;完整系统源码开发笔记详细部署教程&#xff09;✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 在当今数字化时代&#xff0c;信息可视化已成为一种高效的数据理解和传播手段。…

Ubuntu 下 nginx-1.24.0 源码分析 - ngx_array_init 函数

ngx_array_init 定义在 src/core/ngx_array.h static ngx_inline ngx_int_t ngx_array_init(ngx_array_t *array, ngx_pool_t *pool, ngx_uint_t n, size_t size) {/** set "array->nelts" before "array->elts", otherwise MSVC thinks* that "…

基于 DeepSeek + Gemeni 打造 AI+前端的多人聊天室

开源项目 botgroup.chat 介绍 AI 多人聊天室&#xff1a; 一个基于 React 和 Cloudflare Pages(免费一键部署) 的多人 AI 聊天应用&#xff0c;支持多个 AI 角色同时参与对话&#xff0c;提供类似群聊的交互体验。体验地址&#xff1a;https://botgroup.chat 开源仓库&#x…

GPU和FPGA的区别

GPU&#xff08;Graphics Processing Unit&#xff0c;图形处理器&#xff09;和 FPGA&#xff08;Field-Programmable Gate Array&#xff0c;现场可编程门阵列&#xff09;不是同一种硬件。 我的理解是&#xff0c;虽然都可以用于并行计算&#xff0c;但是GPU是纯计算的硬件…

详解单例模式、模板方法及项目和源码应用

大家好&#xff0c;我是此林。 设计模式为解决特定问题提供了标准化的方法。在项目中合理应用设计模式&#xff0c;可以避免重复解决相同类型的问题&#xff0c;使我们能够更加专注于具体的业务逻辑&#xff0c;减少重复劳动。设计模式在定义系统结构时通常考虑到未来的扩展。…

高清下载油管视频到本地

下载工具并安装: yt-dlp官网地址&#xff1a; GitHub - yt-dlp/yt-dlp: A feature-rich command-line audio/video downloader ffmpeg官网地址&#xff1a; Download FFmpeg 注&#xff1a;记住为其添加环境变量 操作命令&#xff1a; 该指令表示以720p码率下载VIDEO_UR…

Docker挂载数据显式挂载和隐式挂载的区别

项目使用的Docker file 创建数据卷挂载点&#xff0c;结果发现宿主机目录中的数据卷路径下是空的&#xff0c;才知道docker file中创建的数据卷是隐式挂载&#xff0c;并不会在宿主机上留下持久化数据&#xff0c;随着容器被删除隐式挂载的数据卷也会跟着被删除 后面改为在jen…

IOS UITextField 无法隐藏键盘问题

设置UITextField 键盘按钮返回键为“完成”&#xff0c;即return key 设置done .m代码设置代理 //设置代理协议 UITextFieldDelegate&#xff0c; self.mobileTextField.delegate self; ///点击完成键隐藏键盘 - (BOOL)textFieldShouldReturn:(UITextField *)textField{//取…