数据库表中的存储行格式决定了数据在物理存储时的布局方式,进而对查询和DML操作的引擎性能产生影响。
在InnoDB存储引擎中,支持种行常见的格式行格式主要包括以下四种:
COMPACT:在MySQL 5.0之前是默认的格式,除了存储字段值外,存储还会利用空值列表来保存null值,引擎同时记录变长字段长度列表和记录头信息。支持种行
图片
COMPACT适用于处理大量包含可变长度列(如VARCHAR、格式VARBINARY、存储BLOB和TEXT类型)数据。引擎
对于可变长度列,支持种行前768字节的格式数据存储在B树节点的索引记录中,超出部分存储在溢出页中。存储大于或等于768字节的引擎固定长度列会被编码为可变长度列,可以存储在页外。支持种行
REDUNDANT:在MySQL 5.0版本之前,InnoDB使用的WordPress模板行记录存储方式,较少使用。Redundant 行格式会将该记录中所有列(包括隐藏列)的长度信息存储在“字段长度偏移列表”中。
图片
image.png
DYNAMIC:MySQL 5.7版本引入的DYNAMIC格式是COMPACT格式的升级版本。它延续了COMPACT格式的优势,在处理大型可变长度列时更具灵活性,能够灵活选择将数据存储在页内还是页外。DYNAMIC格式适用于多数应用场景,在存储空间和性能之间取得了一定的平衡。其结构与COMPACT格式大致相似;COMPRESSED:作为MySQL 5.1中InnoDB的新增特性之一,压缩功能能够减小数据在磁盘上的占用空间。然而,其缺点在于增加了CPU的负担,可能导致部分查询性能下降。COMPRESSED行格式在DYNAMIC行格式的站群服务器基础上引入了页外压缩功能。在存储数据时,如果发现可以通过压缩来减小存储空间,系统将选择压缩方式来存储数据。在查询时,数据将会被自动解压并返回结果。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