【MySQL】InnoDB数据存储结构

1、数据页内部结构

第一部分:文件头部+文件尾部

主要包含了对页面之间双向链表的表示、页面校验和、页面最后被修改对应的日志序列位置

第二部分:空闲空间+用户记录+最小最大记录

用户记录

​ 用户记录中的记录按照指定的行格式一条条摆在该区域,相互之间形成单链表。

第三部分:页目录+页面头部

页目录

1、页目录分组的个数如何确定?

由InnoDB规定:最小记录所在的分组只能有一条记录,最大记录所在分组的记录条数只能在18之间,剩下的分组中记录的条数在48之间。

2、页目录结构下如何快速查找记录?

1、通过二分法确定该记录所在的槽,并记录该槽所在分组中主键值最小的那条记录。

2、通过记录的next_record属性遍历该槽所在组中的所有记录。

页面头部

记录了页目录和页面的相关信息

2、InnoDB行格式

CREATE TABLE 表名 ROW_FORMAT=行格式
ALTER TABLE 表名 ROW_FORMAT=行格式

2.1、COMPACT行格式

NULL值列表

为什么定义NULL值列表?

​ 定义NULL值列表是因为数据是需要对齐的,如果没有标注出NULL值的位置,在查询数据的时候有可能会出现混乱,记录的格式为:

  • 1、二进制值为1时,代表该列的值为NULL
  • 2、二进制值为0时,代表该列的值不为NULL

​ 在这个过程中会 跳过主键,因为主键不为空。

记录头信息:
字段大小(bit)描述
delete_mask1该记录是否被删除
min_rec_mask1B+树每层非叶子节点的最小节点
record_type4当前记录类型,0表示普通记录,1表示B+树非叶子节点记录,2表示最小记录,3表示最大记录
heap_no13当前记录在记录堆的位置信息
n_owned3当前记录拥有的记录数
next_record16下一条记录的相对位置,指向下一条记录的逻辑位置

问题

1、使用delete_mask标记当前记录是否被删除,被删除的记录为什么还在页中存储呢?

​ 这些被删除的记录之所以不立即从磁盘上移除,是因为移除它们之后其他记录在磁盘上需要重新排列,导致性能消耗。通过将所有打上删除标记的记录组成垃圾链表,之后如果有新纪录插入到表中来时,可以把这些被删除的记录占用的存储空间覆盖掉。

2、heap_no为什么是从2开始的?

​ MySQL自动给每个页里加了两个虚拟记录,一个代表最小记录名,heap_no值为0;一个代表最大记录,heap_no值为1。

2.2、Dynamic和Compressed行格式

​ Dynamic和Compressed将实际数据存放在溢出页中,Compressed行记录格式会将存储在其中的行数据以zlib的算法进行压缩。

行溢出

​ 一个页的大小为16KB,也就是16384字节,而VARCHAR类型的列最多可以存储65535个字节,这样可能会出现一页存放不下一条记录的情况。这就是行溢出。

  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: MySQL InnoDBMySQL 中一种常用的数据存储引擎,其特点是支持事务处理和外键约束,并且具有良好的性能和可伸缩性。 InnoDB数据存储是以表为单位的,每个表都有一个对应的数据文件,用于存储表中的数据。除了数据文件之外,InnoDB 还有一个索引文件,用于存储索引信息。 InnoDB 使用了一种称为 B+ Tree 的算法来存储和维护索引,这种算法使得索引查询的效率很高。同时,InnoDB 还支持自适应哈希索引,可以提高对哈希索引的查询性能。 InnoDB 还有一个叫做缓冲池的功能,用于缓存常用的数据和索引,可以提高数据访问的效率。 总的来说,MySQL InnoDB 是一种高效的数据存储引擎,适用于许多不同的应用场景。 ### 回答2: MySQL InnoDB是一种常用的数据库存储引擎,它提供了可靠、高性能的数据存储方式。 InnoDB使用B+树索引来组织数据,这种索引结构能够快速地定位到所需的数据行,提高了查询速度。此外,InnoDB还支持主键索引、唯一索引、全文索引等多种索引类型,以满足不同的查询需求。 InnoDB还支持事务处理,它能够保证在多个并发操作的情况下,数据的一致性和完整性。当需要进行一系列的数据操作时,可以通过事务来确保这些操作要么全部成功,要么全部失败,避免了数据的不一致性问题。 另外,InnoDB还提供了行级锁和事务隔离级别。行级锁可以在并发操作时,更细粒度地锁定数据行,提高了并发操作的效率。而事务隔离级别则可以控制事务之间的相互影响,避免了数据的混乱和冲突。 此外,InnoDB还支持自动增量列和外键约束。自动增量列可以自动生成唯一标识,简化了开发的复杂度。而外键约束可以保证数据的一致性,防止出现不合法的引用。 总之,InnoDB是一种功能强大的数据存储引擎,它具有高性能、可靠性和完整性保证等特点,适用于各种规模的应用和数据存储需求。 ### 回答3: InnoDBMySQL关系型数据库管理系统中的一种数据存储引擎。它拥有许多独特的特性,可以提供高度的数据完整性和可靠性。 首先,InnoDB使用事务来管理数据的插入、删除和更新操作。这意味着所有的操作要么全部成功完成,要么全部回滚。这保证了数据的一致性和完整性。 其次,InnoDB支持行级锁定。这意味着在并发操作时,只有被修改的行会被锁定,而不是整个数据表。这提高了多用户环境下的并发性能。 另外,InnoDB还支持外键约束。这意味着在不同的表之间创建关联关系,确保数据的一致性和完整性。当删除或更新主表中的记录时,相关的外键记录也会相应进行操作,防止出现数据不一致的情况。 此外,InnoDB还具有自动崩溃恢复的能力。它具有一个称为“重做日志”的机制,可以记录所有在事务中所做的修改,以便在意外崩溃或系统故障后可以恢复数据到事务开始之前的状态。 总的来说,InnoDBMySQL中一种强大的存储引擎,它提供高度的数据完整性和可靠性,同时还具备了高并发性和灵活性。在开发和管理大规模数据库时,InnoDB是一个非常理想的选择。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Rockict_z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值