innodb数据页和行记录

一 数据页

1.1 简介

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

1.2 结构

在这里插入图片描述

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 结构
在这里插入图片描述

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

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值