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)实际大小通过变长字段长度列表确定。
  • 行溢出时,数据将被存储在溢出页,并通过指针访问。

相关推荐

  1. MySQL一行记录怎么存储

    2024-06-11 00:38:02       37 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-11 00:38:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-11 00:38:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-11 00:38:02       82 阅读
  4. Python语言-面向对象

    2024-06-11 00:38:02       91 阅读

热门阅读

  1. 部署higress到华为云

    2024-06-11 00:38:02       31 阅读
  2. select模块

    2024-06-11 00:38:02       35 阅读
  3. js中如何清除一个对象中指定的键名

    2024-06-11 00:38:02       28 阅读
  4. 仓库管理业务在WMS与ERP中如何抉择

    2024-06-11 00:38:02       33 阅读
  5. 【数据结构】图之邻接矩阵代码实现与dfs、bfs

    2024-06-11 00:38:02       30 阅读
  6. 如何使用Python pottery库

    2024-06-11 00:38:02       32 阅读
  7. 动态规划算法

    2024-06-11 00:38:02       36 阅读
  8. 分享: 动图网站

    2024-06-11 00:38:02       33 阅读
  9. 本地部署 RAGFlow

    2024-06-11 00:38:02       37 阅读
  10. RGMII接口--->(013)FPGA实现RGMII接口(十三)

    2024-06-11 00:38:02       31 阅读
  11. 开机自启动脚本配置

    2024-06-11 00:38:02       31 阅读