`

InnoDB页结构浅析

阅读更多
InnoDB将所有的记录存放在数据库页中(也可以称为数据块)。一般情况下,所有的页大小都是16KB。
      数据页中不仅仅包含实际的记录,还包含其它的一些内容,比如文件头以及文件尾等等。
InnoDB的页包含以下几个部分:
1)      Fil Header:文件头
2)      Page Header:页头
3)      Infimum+Supremum Records:最小虚记录以及最大虚记录
4)      User Records:用户记录
5)      Free Space:自由堆
6)      Page Directory:目录槽
7)      Fil Trailer:文件尾
     从这几个部分,我们可以看到。页中的2与6是与页管理有关,页中的1和7与文件管理有关。其中的3、4、5是记录相关的。每个页一旦分配,一定具有最小虚记录与最大虚记录,可以分别想像成无穷小、无穷大。当用户插入一条记录,就会从5(自由堆)中分配一块空间用来存储该记录。

1 Fil Header(文件头)
   文件头由8个部分组成,见表1:
                              表1:文件头的组织形式
名称 长度 含义
FIL_PAGE_SPACE 4 space id
FIL_PAGE_OFFSET 4 页号
FIL_PAGE_PREV 4 上一页
FIL_PAGE_NEXT 4 下一页
FIL_PAGE_LSN 8 日志序列号
FIL_PAGE_TYPE 2 页类型
FIL_PAGE_FILE_FLUSH_LSN 8 文件的日志序列号,仅文件的第一页的此字段有效
FIL_PAGE_ARCH_LOG_NO 4 归档日志文件号



2 Page Header(页头)
   页头由14个部分组成,见表2:
                               表2:文件头的组织形式
名称 长度 含义
PAGE_N_DIR_SLOTS 2 记录槽的数量,初始值为2,因为页至少具有最小虚记录与最大虚记录
PAGE_HEAP_TOP 2 指向堆中的第一条记录
PAGE_N_HEAP 2 堆记录的数量,初始值为2
PAGE_N_FREE 2 指向第一个空闲记录
PAGE_GARBAGE 2 被删除记录的总字节数
PAGE_LAST_INSERT 2 指向最后一个插入的记录
PAGE_DIRECTION 2 记录顺序
PAGE_N_DIRECTION 2 连续同方面插入的数量
PAGE_N_RECS 2 用户记录的数量
PAGE_MAX_TRX_ID 8 更改此页的最高事务ID(仅仅对二级索引有效)
PAGE_LEVEL 2 该页在索引中的层次(页节点是0)
PAGE_INDEX_ID 8 所属的索引ID
PAGE_BTR_SEG_LEAF 10 索引页节点段
PAGE_BTR_SEG_TOP 10 索引内节点段



3 Infimum+Supremum Records(最小虚记录以及最大虚记录)
   最小虚拟记录与最大虚拟记录,既是所谓的负无穷大、正无穷大。这两个记录是在页创建时创建的,并且永远不会被删除。它们的作用在于作为查询的屏障,避免越界。

4 User Records(用户记录)
  在该区域中,将可以找到所有用户插入的记录。有两种方式来查找用户记录,一种为有序,另外一种为无序。
   InnoDB不会在该区域按照记录进行B树的key排序(这会导致频繁的数据移动),所以,插入时是直接将新行插入现有行的后面(从自由堆的顶部分配空间),或者使用空闲记录的空间(空闲记录即被删除的记录,记录被删除后,并不立即回收该记录所占的空间)。
但是,B树的定义是记录必须按照key值进行排序,因此每个记录都含有一个指针(next字段)指向下一条记录(以key值排序)。换句话说,这些记录有一个单向链表。所以,InnoDB在查找时可以按照key排序的方式进行查找。

5 Free Space(自由堆)
   自由堆,可以从该堆上为新记录分配所需空间。

6 Page Directory(目录槽)
   和其它数据库不同的是,InnoDB并不会为每一个记录分配一个目录。每六个记录分配一个目录。

7 Fil Trailer(文件尾)
  文件尾记录的是文件的LSN。



本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/whyangwanfu/archive/2007/12/10/1927762.aspx
分享到:
评论

相关推荐

    Innodb存储引擎浅析—事务系统

    ### Innodb存储引擎浅析—事务系统 #### 学述 在MySQL的众多存储引擎中,InnoDB无疑是最为重要且被广泛使用的之一。本文旨在深入解析InnoDB存储引擎中的事务处理机制及其背后的设计原理。 #### 存储引擎介绍 在...

    MySQL核心Innodb存储引擎浅析—事务系统

    ### MySQL核心Innodb存储引擎浅析—事务系统 #### 存储引擎介绍 在MySQL中,存储引擎是处理表的存储方式的核心组件之一。不同的存储引擎提供了不同的特性,如事务支持、锁定粒度等。其中,MyISAM和InnoDB是最常用...

    浅析InnoDB索引结构

    【InnoDB索引结构浅析】 InnoDB是MySQL数据库中常用的一种存储引擎,以其支持事务处理和行级锁定而著名。在InnoDB中,索引的构建和组织方式对数据库性能有着重大影响。本文将深入探讨InnoDB的索引特性,特别是聚集...

    MySQL数据库技术分享 MySQL查询优化浅析 共32页.pdf

    InnoDB层的统计信息如dict_table_struct则提供了更详细的表结构信息。此外,还有动态收集的统计信息和语句级统计信息,如records_in_range,用于更精确地估算不同Range的记录数量。 统计信息的收集策略也是优化的...

    MySQL查询优化浅析

    ### MySQL查询优化浅析 #### 一、查询优化概述 查询优化是数据库管理系统(DBMS)中的一个重要组成部分,其主要目标是在接收到一个SQL查询后,寻找最高效的执行计划,以尽可能快的速度返回查询结果。这一过程涉及到...

    浅析MysQL B-Tree 索引

    不同的存储引擎也可能使用不同的存储结构,i如,NDB集群存储引擎内部实现使用了T-Tree结构存储这种索引,即使其名字是BTREE;InnoDB使用的是B+Tree。 B-Tree通常一位这所有的值都是按顺序存储的,并且每一个叶子页道...

    浅析mysql 共享表空间与独享表空间以及他们之间的转化

    对于innodb的数据结构,首先要解决两个概念性的问题: 共享表空间以及独占表空间。什么是共享表空间和独占表空间共享表空间以及独占表空间都是针对数据的存储方式而言的。共享表空间: 某一个数据库的所有的表数据,...

    MySQL replace into 语句浅析(一)

    表结构 代码如下: CREATE TABLE `yy` (  `id` bigint(20) NOT NULL,  `name` varchar(20) DEFAULT NULL,  PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; root@test 02:43:58>insert into yy values

    浅析MySQL内存的使用说明(全局缓存+线程缓存)

    3. `innodb_additional_mem_pool_size`:这是InnoDB用来存储数据字典和其他内部数据结构的内存池,通常不需要设置得过大,但应确保足够满足系统需求。如果不足,MySQL会在错误日志中给出警告。 4. `innodb_log_...

    浅谈MySQL数据库的备份与恢复

    一、MySQL 常见的备份方式 1. 直接拷贝数据库文件(物理拷贝) 2. 使用 mysqldump 工具备份 ...innodb 的 redo 日志 2. 数据文件 >>>对于 myisam 来说: 表结构信息:.frm 数据信息:.myd 数据索引信息;.myi >>

    浅析MySQL 备份与恢复

    最基本的备份可能仅包含数据和表结构,但为了更全面的恢复,可能还需要备份二进制日志(Binlog)、InnoDB事务日志、主/从服务器配置文件,甚至是数据库服务器的操作系统配置。物理备份直接复制数据库文件,恢复速度快...

    ysql-646857.pdf

    ) ENGINE=InnoDB AUTO_INCREMENT=12212 DEFAULT CHARSET=utf8; ``` 插入数据 插入一些示例数据到 menu 表中: ```sql INSERT INTO `menu` VALUES ('0', null, '菜单0', ' ', '1'); INSERT INTO `menu` VALUES ('1',...

Global site tag (gtag.js) - Google Analytics