一、问题解析
数据库表的行格式决定了一行数据是如何进行物理存储的,进而影响查询和DML操作的性能。
在InnoDB中,常见的行格式有4种:
1COMPACT :是MySQL 5.0之前的默认格式,除了保存字段值外,还会利用空值列表保存null值,还会记录变长字段长度列表和记录头信息。
变长字段长度列表
记录头信息
NULL值列表
额外信息
真实数据
列2数据
列1数据
列N数据
3数据
1、COMPACT 适合处理大量包含可变长度列(如VARCHAR、VARBINARY、BLOB和TEXT类型)的数据。
对于可变长度列,前768字节的数据存储在B树节点的索引记录中,超出部分存储在溢出页中。大于或等于768字节的固定长度列会被编码为可变长度列,并可以存储在页外。
2、REDUNDANT :Redundant 是 MySQL5.0 版本之前 InnoDB 的行记录存储方式,用的比较少,Redundant 行格式会把该条记录中所有列 (包括隐藏列) 的长度信息都存储到 '字段长度偏移列表' 中。
字段长度偏移列表
真实数据
列N数据
记录头信息
额外信息
列1数据
列3数据
列2数据
3、DYNAMIC:DYNAMIC格式在MySQL 5.7版本引入,是COMPACT格式的改进版。它保持了COMPACT格式的优点,同时在存储大的可变长度列时更加灵活,能够动态地选择存储在页内或页外。DYNAMIC格式适用于大部分的应用场景,并在存储空间和性能上做了一定的平衡。其结构和COMPACT大致相同;
4、COMPRESSED:是MySQL 5.1中InnoDB的新特性之一,它可以在存储数据时对数据进行压缩,从而减小磁盘占用空间。它的缺点是增加了CPU的使用,可能会降低一些查询的性能。COMPRESSED 行格式是在 DYNAMIC 行格式的基础上添加了页外压缩功能。在存储时,如果发现数据可以通过压缩减小存储空间,就会使用压缩方式来存储数据。在查询时,会自动解压缩数据并返回结果。
5、BARRACUDA:是MySQL 5.7引入的一种新格式,相对于前面的格式,支持更多的高级特性,如动态行格式、行级压缩、空间管理等。
行格式 | 紧凑的存储特性 | 增强的可变长度列存储 | 大索引键前缀支持 | 压缩支持 | 支持的表空间类型 | 所需文件格式 |
REDUNDANT | 否 | 否 | 否 | 否 | system, file-per-table, general | Antelope or Barracuda |
COMPACT | 是 | 否 | 否 | 否 | system, file-per-table, general | Antelope or Barracuda |
DYNAMIC | 是 | 是 | 是 | 否 | system, file-per-table, general | Barracuda |
COMPRESSED | 是 | 是 | 是 | 是 | file-per-table, general | Barracuda |
二、粉丝福利
我是浮生,一个工作十四年经验的Java程序员!
最近很多同学问我有没有java学习资料,我根据我从小白到架构师多年的学习经验整理出来了一份80W字面试解析文档、简历模板、学习路线图、java必看学习书籍 、 需要的小伙伴 可以关注我
公众号:“ 灰灰聊架构 ”, 回复暗号:“ 321 ”即可获取