本页讨论:
  • 数据字典介绍
  • 数据字典(InnoDB系统表)

数据字典介绍

InnoDB数据字典由内部系统表组成。这些系统表包含用于跟踪对象(如表,索引和列)的元数据。


在MySQL8.0 之前,由于历史原因。
Data Dictionary除了存在于InnoDB系统表空间。
还存在于文件系统的 .FRM, .TRG, .OPT ⽂件中。
还存在于系统表中(基于MyISAM存储引擎的⾮事务引擎表中)。

而且在一定程度上彼此的信息是重叠的。


在MySQL8.0,Data Dictionary 全部存在于Data Dictionary Storage Engine(即 InnoDB表中)



数据字典(InnoDB系统表)

innodb系统表空间内的数据字典实现方式:
有4个最基本的系统表来存储表的元数据:表、列、索引、索引列等信息。这4个表分别是SYS_TABLES、SYS_COLUMNS、SYS_INDEXES、SYS_FIELDS

SYS_TABLES
存储所有以InnoDB为存储引擎的表,每条记录对应一个表。

该表的列分别是:
NAME:表名 ID:表的ID号 N_COLS:表的列数 TYPE:表的存储类型,包括记录的格式、压缩等信息 MIX_ID、MIX_LEN、CLUSTER_NAME:暂时未用 SPACE:这个表所在的表空间ID。
这个表在NAME上有聚集索引,ID上有唯一二级索引。

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

该表的列分别是:
TABLE_ID:该列所属表的ID POS:该列在表中第几列 NAME:列名 MTYPE:列的主数据类型 PRTYPE:列的精确数据类型 LEN:列数据长度,不包括varchar类型,因为该类型在记录里面已经存储了 PREC:列数据的精度。
该表的主键列是(TABLE_ID,POS)

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

该表的列分别是:
TABLE_ID:该列所属表的ID ID:索引的索引号 NAME:索引名 N_FIELDS:索引包含的列数 TYPE:索引类型,包括聚集索引、唯一索引、DICT_UNIVERSAL、DICT_IBUF SPACE:索引所在表的表空间ID PAGE_NO:该索引对应的B+树的根页面号。
该表主键(TABLE_ID,ID)

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

该表的列分别是:
INDEX_ID:该列所在的索引ID POS:该列在索引中第几列 COL_NAME:列名
该表主键是(INDEX_ID,POS)




上一篇:系统表空间
下一篇:双写缓冲区

成为你想看到的世界变革力量

创建者:万乐荣
最后更新时间 : 2018年9月8日 14:18

评论