InnoDB数据字典详解-系统表

1、简介

InnoDB中,实际上看不到系统表。有4个最基本的系统表来存储表的元数据:表、列、索引、索引列等信息。这4个表分别是SYS_TABLES、SYS_COLUMNS、SYS_INDEXES、SYS_FIELDS。下面分别介绍

2、SYS_TABLES

存储所有以InnoDB为存储引擎的表,每条记录对应一个表。该表的列分别是:

NAME:表名

ID:表的ID号

N_COLS:表的列数

TYPE:表的存储类型,包括记录的格式、压缩等信息

MIX_ID、MIX_LEN、CLUSTER_NAME:暂时未用

SPACE:这个表所在的表空间ID。

这个表在NAME上有聚集索引,ID上有唯一二级索引。

3、SYS_COLUMNS

存储列信息,每一列对应一条记录。表列:

TABLE_ID:该列所属表的ID

POS:该列在表中第几列

NAME:列名

MTYPE:列的主数据类型

PRTYPE:列的精确数据类型

LEN:列数据长度,不包括varchar类型,因为该类型在记录里面已经存储了

PREC:列数据的精度。

该表的主键列是(TABLE_ID,POS)

4、SYS_INDEXES

存储索引信息,每条记录对应一个索引。

TABLE_ID:该列所属表的ID

ID:索引的索引号

NAME:索引名

N_FIELDS:索引包含的列数

TYPE:索引类型,包括聚集索引、唯一索引、DICT_UNIVERSAL、DICT_IBUF

SPACE:索引所在表的表空间ID

PAGE_NO:该索引对应的B+树的根页面号。

该表主键(TABLE_ID,ID)

5、SYS_FIELDS

存储定义的索引列,每条记录对应一个索引列:

INDEX_ID:该列所在的索引ID

POS:该列在索引中第几列

COL_NAME:列名

该表主键是(INDEX_ID,POS)

6、数据字典表根页面位置,在innodb中使用系统表空间0号文件的第7号页面存储。该页面存储了上面4个表的5个根页号,以及下一个表ID值、下一个索引ID值、下一个表空间ID值、rowid。第7号页结构如下所示:

dict0boot.h::

/* Dictionary header offsets */
#define DICT_HDR_ROW_ID     0   /* The latest assigned row id */
#define DICT_HDR_TABLE_ID   8   /* The latest assigned table id */
#define DICT_HDR_INDEX_ID   16  /* The latest assigned index id */
#define DICT_HDR_MAX_SPACE_ID   24  /* The latest assigned space id,or 0*/
#define DICT_HDR_MIX_ID_LOW 28  /* Obsolete,always DICT_HDR_FIRST_ID*/
#define DICT_HDR_TABLES     32  /* Root of SYS_TABLES clust index */
#define DICT_HDR_TABLE_IDS  36  /* Root of SYS_TABLE_IDS sec index */
#define DICT_HDR_COLUMNS    40  /* Root of SYS_COLUMNS clust index */
#define DICT_HDR_INDEXES    44  /* Root of SYS_INDEXES clust index */
#define DICT_HDR_FIELDS     48  /* Root of SYS_FIELDS clust index */  

#define DICT_HDR_FSEG_HEADER    56  /* Segment header for the tablespace  segment into which the dictionary header is created */ 

下一节讲解系统表的加载及普通表数据字典的加载原理。

原文地址:http://blog.51cto.com/yanzongshuai/2095128

时间: 2024-08-29 21:33:21

InnoDB数据字典详解-系统表的相关文章

【mysql】mysql innodb 配置详解

MySQL innodb 配置详解 innodb_buffer_pool_size:这是InnoDB最重要的设置,对InnoDB性能有决定性的影响.默认的设置只有8M,所以默认的数据库设置下面InnoDB性能很差.在只有InnoDB存储引擎的数据库服务器上面,可以设置60-80%的内存.更精确一点,在内存容量允许的情况下面设置比InnoDB tablespaces大10%的内存大小. innodb_data_file_path:指定表数据和索引存储的空间,可以是一个或者多个文件.最后一个数据文件

全面inux主机安全配置详解--系统OS安全(第一部分)

Linux主机安全配置详解 系统安全分为: 第一部分: BIOS密码,更改合适启动选项(禁止改bios/禁止更改第一启动选项,防止恶意的引导) GRUB密码 系统密码(密码策略) 分区加密 第二部分: 最小权限法(su/sudo) 最小服务法 文件安全(suid/sgid/stick/chattr) pam模块的使用 升级系统和软件 系统安全: BIOS密码(bios/cmos) 调整BIOS引导设置 修改启动顺序,正确做法:第一启选项为磁盘 设置管理密码 禁用Ctrl+Alt+Del重启热键

全面inux主机安全配置详解--系统OS安全(第二部分)

系统安全 最小服务法 文件安全(suid/sgid/stick/chattr) 升级系统和软件 最小权限法(su/sudo) SSH安全建议 最小服务法(system v/xinetd) 关闭不需要的服务: # vim /root/service.sh #!/bin/bash service xinetd stop chkconfig xinetd off services="network sshd syslog lvm2-monitor messagebus sendmail crond g

mysql 查看存储引擎的状态 show engine innodb status 详解

首先,让我们来了解一下 SHOW INNODB STATUS 输出的基础,它打印了很多关于 InnoDB 内部性能相关的计数器.统计.事务处理信息等.在 MySQL 5 中,InnoDB 的性能统计结果也在 SHOW STATUS 结果中显示了.大部分和 SHOW INNODB STATUS 的其他信息相同,在旧版本中还没有这个功能. SHOW INNODB STATUS 中的很多统计值都是每秒更新一次的,如果你打算利用这些统计值的话,那么最好统计一段时间内的结果.InnoDB 首先输出以下信息

显示引擎innodb状态详解

很多人让我来阐述一下  SHOW INNODB STATUS 的输出信息,了解SHOW INNODB STATUS都输出了几个什么信息,并且我们能够这些信息中获取什么资讯,得以提高MySQL性能. 首先,让我们来了解一下SHOW INNODB STATUS输出的基础,它打印了很多关于InnoDB内部性能相关的计数器,统计,事务处理信息等.在mysql 5中,InnoDB的性能统计结果也在  SHOW STATUS  结果中显示了.大部分和SHOW INNODB STATUS的其他信息相同,在旧版

详解Bootstrap表单组件

表单常见的元素主要包括:文本输入框.下拉选择框.单选框.复选框.文本域.按钮等.下面是不同的bootstrap版本: LESS:  forms.less SASS:  _forms.scss bootstrap仅对表单内的fieldset.legend.label标签进行了定制 fieldset { min-width: 0; padding: 0; margin: 0; border: 0; } legend { display: block; width: 100%; padding: 0;

mysql-5.7 show engine innodb status 详解

一.show engine innodb status 简介: show engine innodb status 是mysql提供的一个用于查看innodb引擎时间信息的工具,就目前来说有两处比较 常用的地方一.死锁分析 二.innodb内存使用情况 二.通过show engine innodb status 查看内存使用情况: ---------------------- BUFFER POOL AND MEMORY ---------------------- Total large me

【转】MySQL存储引擎中的MyISAM和InnoDB区别详解

转自:http://www.jb51.net/article/62457.htm MyISAM是MySQL的默认数据库引擎(5.5版之前),由早期的ISAM(Indexed Sequential Access Method:有索引的顺序访问方法)所改良.虽然性能极佳,但却有一个缺点:不支持事务处理(transaction).不过,在这几年的发展下,MySQL也导入了InnoDB(另一种数据库引擎),以强化参考完整性与并发违规处理机制,后来就逐渐取代MyISAM. InnoDB,是MySQL的数据

MyISAM和InnoDB区别详解

MyISAM是MySQL的默认数据库引擎(5.5版之前),由早期的ISAM(Indexed Sequential Access Method:有索引的顺序访问方法)所改良.虽然性能极佳,但却有一个缺点:不支持事务处理(transaction).不过,在这几年的发展下,MySQL也导入了InnoDB(另一种数据库引擎),以强化参考完整性与并发违规处理机制,后来就逐渐取代MyISAM. InnoDB,是MySQL的数据库引擎之一,为MySQL AB发布binary的标准之一.InnoDB由Innob