MySQL 行格式(Row Format)

行格式简介

表的行格式决定了其行的物理存储方式,进而会影响查询和DML操作的性能。

InnoDB存储引擎支持四种行格式:REDUNDANT、 COMPACT、DYNAMICCOMPRESSED。

MySQL版本5.7默认使用DYNAMIC行格式。

InnoDB行格式概述
行格式紧凑的存储
特性
增强的可变长度色谱柱存储大索引键前缀支持压缩支持支持的表空间类型所需文件格式
REDUNDANTNoNoNoNosystem, file-per-table, generalAntelope or Barracuda
COMPACTYesNoNoNosystem, file-per-table, generalAntelope or Barracuda
DYNAMICYesYesYesNosystem, file-per-table, generalBarracuda
COMPRESSEDYesYesYesYesfile-per-table, generalBarracuda

DYNAMIC行格式介绍

DYNAMIC行格式由变长字段列表  +  NULL值列表  + 记录头信息  + 列值组成。

1.变长字段长度列表

比如VARCHAR(M)类型的列称为变长字段,其真实数据存在列值,而占用的字节长度(十六进制表示)逆序存在变长字段长度列表。

2.NULL值列表

将每个允许存储NULL的列对应一个二进制位,二进制位按照列的顺序逆序排列,如果列值NULL则记录1到NULL值列表。不为NULL则记录0。

3.记录头信息

它是由固定的5个字节组成。5个字节也就是40个二进制位。

记录头信息
名称大小(B)描述
预留位2未使用
delete_mask1标记该记录是否被删除
min_rec_mask1B+树的每层非叶子节点中的最小记录都会添加该标记
n_owned4表示当前记录拥有的记录数
heap_no13表示当前记录在记录堆的位置信息
record_type3表示当前记录的类型。
0普通记录,1:B+树非叶子节点记录,2:最小记录,3最大记录
next_record16表示下一条记录的相对位置

 4.列值

列值分为隐藏列和真实数据列。

隐藏列为ROW_ID(行ID)、TRX_ID(事务ID)、ROLL_PTR(回滚指针)。

真实数据列为用户表中的值。

 

其他行格式和DYNAMIC差不多,只是对行溢出处理方式不同,DYNAMIC行溢出是把所有的字节都存储到其他页面中,只在记录的真实数据处存储其他页面的地址,COMPACT是记录的真实数据处存储字符串的前768个字节,COMPRESSED会采用压缩算法对页面进行压缩,以节省空间。

 

那么对于一个表

学生成绩表
idnamescore
1穗乃果12
260
3海未 

真实存储形式是这样的

学生成绩表
变长字段列表NULL值列表记录头信息行ID事务ID回滚指针idnamescore
2 30忽略 1021穗乃果12
2 10忽略 3256260
22忽略 33803海未 

实际值都是十六进制表示,这里只是为了方便阅读。行ID(row_id)当表中没有唯一主键索引和非空的唯一索引才会存在。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值