innodb数据页和行记录

一 数据页

1.1 简介

修改数据库表中记录时,并不是实时与磁盘中数据库同步,而是以页为单位, 定期同步内存中页数据到磁盘中,从而提高mysql的性能。

1.2 结构

innodb数据页和行记录_第1张图片

File Header: 表示页的一些通用信息
Page Header: 数据也专有的一些信息
Infimum+supremum: 最小和最大记录
User Records: 用户记录, 用户存储的记录都存储在这里
Free Space: 空闲空间, 最开始的时候只有free space没有User Records 每增加一条记录就会从free space分配一块空间给User Records存记录;
Page Directory: 页目录, 通过页目录可以快速的查询到记录
File Trailer:检验页是否完整的内容

记录是单向链表结构: 记录中头信息中有next_record属性记录着下一个记录, 记录是通过主键进行排序, 每个记录存储着主键的下一个记录
数据页是双向链表结构: File Header中记录中页的上一页和下一页,从而串成了双向链表结构

数据页会分成许多组, 每个组中最后一个记录的偏移量作为,存放到 Page Directory中, 通过主键查找数据很快,步骤如下:
1)先根据二分法查找到记录位于哪个槽中;
2)在槽中遍历,找到具体的记录;

一个页中数据一般是16k, 当存储的数据超过这个值,会重新分配其他页进行存储。

二 行记录

2.1 简介

innodb插入表数据是以记录为单位进行的, 记录在磁盘上的存储方式称为 行记录。

2.2 行格式分类

compact 常用
Redundant
Dynamic
Compressed

2.3 compact行格式

1 语法

create table 表名(列字段)   ROW_FORMAT=行格式

2 结构
innodb数据页和行记录_第2张图片

额外信息:
变长字段长度列表: 用来存放varchar 等类型字段存储数据的长度
NULL值列表: 存储列字段为NULL的数据记录在此
记录头信息: 存储着下一个记录的地址等信息

真实信息:
隐藏字段:
row_id 行记录唯一标识, 当客户端自定义主键字段时,此字段不存在,当客户端没有指明主键时使用该字段作为主键
transaction_id 事务id,所有记录都有
roll_pointer 回滚指针,所有记录都有

你可能感兴趣的:(mysql)