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-11-02 18:04:10