博客
关于我
《Mysql是怎样运行的》读书笔记四
阅读量:810 次
发布时间:2019-03-24

本文共 949 字,大约阅读时间需要 3 分钟。

MySQL的InnoDB存储引擎以页面为基本读写单位,记录数据以.page结尾。作为常用的事务型数据库引擎,InnoDB具有持久化特性,即使服务器关闭数据也不会丢失。为了高效管理数据,InnoDB采用了行存储格式,其中COMPACT是最基础的行格式之一。以下将详细介绍COMPACT行格式的存储原理。

记录的组成结构

一条记录可以分为三个主要部分:额外信息、记录头信息和真实数据。这些部分共同构成记录存储在磁盘上的结构。

1. 记录的额外信息

(1) 变长字段长度列表

InnoDB行存储在磁盘上时,需要处理那些长度不固定(如VARCHAR、TEXT等变长字段)的数据。为了记录这些字段所占空间,COMPACT行格式采用了一个变长字段长度列表,该列表位于记录的开头部分。列表中的每个值代表相应变长字段所占用的字节数,存储顺序为列的访问顺序逆序排列。

例如:

  • 列1变长字段长度为100字节
  • 列2变长字段长度为150字节
  • 列3变长字段长度为200字节

(2) NULL值列表

InnoDB记录中某些列可能存在NULL值,以优化存储和查询效率,NULL值列表用于记录哪些列存在NULL值。该列表的存储方式采用位操作:

  • 每一个位代表一列
    • 位值为1:表示该列的值为NULL
    • 位值为0:表示该列的值不为NULL
  • 所需二进制位的字节数由记录中允许存储NULL值的列数量决定。如果二进制位数不足一个字节,高位补充0。

(3) 记录头信息

记录头由5个固定的字节组成,主要用于描述记录的存储属性和管理信息。这些字节包含以下内容:

  • 行格式类型(如COMPACT)
  • 是否存在Sort_key列(用于索引排序)
  • 行长度(固定大小或动态扩展)

2. 记录的真实数据

CPACT行格式的真实数据部分存储了定义的列及其对应的值,除此之外,InnoDB还为每条记录默认增加了以下隐藏列:

  • row_id: 行唯一标识符,6字节(用于唯一标识记录)
  • trx_id: 事务唯一标识符,6字节(用于标记当前记录所参与的事务)
  • roll_pointer: 事务回滚指针,7字节(用于记录回滚操作的位置)

通过上述结构,InnoDB能够高效地存储和管理各种数据类型,确保数据一致性和完整性。理解这些存储机制有助于优化数据库性能和磁盘使用效率。

转载地址:http://auhkk.baihongyu.com/

你可能感兴趣的文章
Oracle PLSQL Demo - 17.游标查询个别字段(非整表)
查看>>
【C/C++学院】(6)构造函数/析构函数/拷贝构造函数/深copy浅copy
查看>>
oracle rac 安装 PRVG-13606 ntp 同步报错解决过程
查看>>
Oracle RAC性能调整的方案
查看>>
oracle rac集群的东西之QQ聊天
查看>>
UML— 用例图
查看>>
Oracle Schema Objects——Tables——Table Compression
查看>>
oracle scott趣事
查看>>
oracle script
查看>>
Oracle select表要带双引号的原因
查看>>
Oracle SOA Suit Adapter
查看>>
Oracle Spatial GeoRaster 金字塔栅格存储
查看>>
Oracle spatial 周边查询SQL
查看>>
Oracle Spatial空间数据库建立
查看>>
UML— 活动图
查看>>
oracle sqlplus已停止工作,安装完成客户端后sqlplus报“段错误”
查看>>
oracle SQLserver 函数
查看>>
oracle sql分组(group,根据多个内容分组)在select之后from之前 再进行select查询,复杂子查询的使用
查看>>
UML— 时序图
查看>>
Oracle Statspack分析报告详解(一)
查看>>