Mysql行格式DYNAMIC和COMPACT区别

MySQL的InnoDB存储引擎支持多种行格式,其中DYNAMIC和COMPACT是两种常见的行格式,它们各自有着不同的特性和应用场景。下面将详细对比这两种行格式的主要区别,以便于在设计数据库时做出合适的选择。

COMPACT行格式

COMPACT是MySQL 5.0之后引入的一种行记录存储方式,旨在提高数据页的利用率,使每个数据页能够存储更多的行记录。COMPACT格式的特点包括:

  1. 变长字段处理:对于VARCHAR、VARBINARY、BLOB等变长字段,COMPACT格式会在记录的真实数据部分存储实际长度和值。对于BLOB字段,如果数据超过768字节,超出部分会被存储到溢出页,记录中只保留20字节的指针指向溢出页。
  2. 固定长度字段优化:对于CHAR类型的字段,COMPACT格式会保留其声明的固定长度,即使实际存储的数据小于声明长度。
  3. 记录头部:COMPACT格式的记录头部包含了一些额外的信息,如记录的状态位、下一个记录的偏移量等,这有助于快速遍历记录和管理记录状态。

DYNAMIC行格式

从MySQL 5.7版本开始,DYNAMIC成为默认的行格式,它基于COMPACT格式进行了改进,主要区别在于处理大字段的方式:

  1. BLOB字段处理优化:与COMPACT格式相比,DYNAMIC行格式对于BLOB字段采取了更为激进的策略,无论BLOB字段的值大小如何,都只会直接在记录中存储一个20字节的指针指向溢出页,而不会在记录中保留任何实际数据。这种处理方式使得单个记录占用的空间更少,从而在数据页中可以存放更多的记录。
  2. 提高存储效率:由于DYNAMIC行格式对大字段的这种处理方式,它在存储大量含有大文本或二进制数据的表时,能更高效地利用存储空间,减少碎片化,尤其是在更新频繁导致行记录变长时。
posted @   令小飞  阅读(3)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示