当前位置: 首页 > news >正文

MySQL中的一行记录是怎么存储的

MySQL数据存储位置

  • 数据存储在磁盘上的文件中,由存储引擎实现。
  • InnoDB是默认存储引擎,数据存放在/var/lib/mysql/目录下,每个数据库对应一个目录。

表空间文件结构

  • 表空间由段(segment)、区(extent)、页(page)、行(row)组成。
  • 页是磁盘管理的最小单元,通常大小为16KB。
  • 区是B+树组织数据时用于提高顺序I/O性能的单位,大小为1MB。

InnoDB行格式

  • 有4种行格式:Redundant、Compact、Dynamic和Compressed。
  • Compact是MySQL 5.1版本后的默认行格式,Dynamic从MySQL 5.7版本后成为默认。

Compact行格式详解

  • 包含记录的额外信息和记录的真实数据。
  • 额外信息包括变长字段长度列表、NULL值列表、记录头信息。
  • 变长字段长度列表逆序存放,提高CPU Cache命中率。
  • NULL值列表用二进制位表示,节省空间。
  • 记录头信息包含delete_mask、next_record、record_type等。

记录的真实数据

  • 包含用户定义字段和三个隐藏字段:row_id、trx_id、roll_pointer。
  • row_id:如果没有主键或唯一约束,占用6字节。
  • trx_id:事务ID,必需,占用6字节。
  • roll_pointer:指向记录上一个版本的指针,必需,占用7字节。

varchar(n)最大取值

  • 一行记录最大字节数为65535,包括变长字段长度列表和NULL值列表。
  • 根据字符集不同,varchar(n)的最大n值会有所不同。

行溢出处理

  • 当数据页无法存储一条完整记录时,InnoDB将溢出数据存放到溢出页。
  • Compact行格式在记录真实数据处保存部分数据,剩余数据放在溢出页。
  • Compressed和Dynamic行格式采用完全行溢出方式,记录真实数据处只存储指向溢出页的指针。

总结

  • NULL值通过NULL值列表存储,不占用真实数据部分。
  • varchar(n)实际大小通过变长字段长度列表确定。
  • 行溢出时,数据将被存储在溢出页,并通过指针访问。

相关文章:

  • 【QT5】<重点> QT串口编程
  • Java 和 Kotlin Lambda 表达式详解
  • vue简介实例
  • 第二十七章HTML.CSS综合案例(三)
  • react中useEffect函数的详细用法
  • Unity3D MMORPG加载背包配置表详解
  • C#中数组ProtoBuf使用问题
  • c# 二维图形绘制实践
  • 【Python高级编程】OpenCV来处理视频数据
  • 【数据结构(邓俊辉)学习笔记】二叉搜索树02——查找、插入和删除
  • mysql对VARCHAR和int的误解
  • c++ | 动态编译|虚函数表|虚函数
  • HTML和CSS基础(二)
  • 航空电子设备 MIL-STD-1553 收发器 HI-1573 / HI-1574
  • LinkedList与链表
  • 【跃迁之路】【733天】程序员高效学习方法论探索系列(实验阶段490-2019.2.23)...
  • 03Go 类型总结
  • 4个实用的微服务测试策略
  • android百种动画侧滑库、步骤视图、TextView效果、社交、搜房、K线图等源码
  • eclipse的离线汉化
  • isset在php5.6-和php7.0+的一些差异
  • JAVA 学习IO流
  • java第三方包学习之lombok
  • Python中eval与exec的使用及区别
  • React的组件模式
  • React中的“虫洞”——Context
  • SAP云平台里Global Account和Sub Account的关系
  • Spring核心 Bean的高级装配
  • Vue组件定义
  • 半理解系列--Promise的进化史
  • 闭包,sync使用细节
  • 基于 Babel 的 npm 包最小化设置
  • 悄悄地说一个bug
  • 设计模式(12)迭代器模式(讲解+应用)
  • 腾讯视频格式如何转换成mp4 将下载的qlv文件转换成mp4的方法
  • 突破自己的技术思维
  • 小程序上传图片到七牛云(支持多张上传,预览,删除)
  • 一、python与pycharm的安装
  • 优化 Vue 项目编译文件大小
  • 关于Kubernetes Dashboard漏洞CVE-2018-18264的修复公告
  • 如何通过报表单元格右键控制报表跳转到不同链接地址 ...
  • #1014 : Trie树
  • #传输# #传输数据判断#
  • (007)XHTML文档之标题——h1~h6
  • (delphi11最新学习资料) Object Pascal 学习笔记---第14章泛型第2节(泛型类的类构造函数)
  • (Pytorch框架)神经网络输出维度调试,做出我们自己的网络来!!(详细教程~)
  • (二)Eureka服务搭建,服务注册,服务发现
  • (附源码)springboot猪场管理系统 毕业设计 160901
  • (亲测有效)解决windows11无法使用1500000波特率的问题
  • (四)opengl函数加载和错误处理
  • (原創) 人會胖會瘦,都是自我要求的結果 (日記)
  • (源码版)2024美国大学生数学建模E题财产保险的可持续模型详解思路+具体代码季节性时序预测SARIMA天气预测建模
  • (转) SpringBoot:使用spring-boot-devtools进行热部署以及不生效的问题解决
  • .Family_物联网
  • .htaccess配置常用技巧