mysql业务字典表_mysql字典表 – 提供7*24专业数据库(Oracle,SQL Server,MySQL等)恢复和Oracle技术服务@Tel:+86 13429648788 - 惜分飞...

本文详细介绍了MySQL的四个核心数据字典表:SYS_TABLES, SYS_INDEXES, SYS_COLUMNS和SYS_FIELDS,用于理解数据库内部结构和恢复过程。SYS_TABLES记录表信息,SYS_INDEXES记录索引详情,SYS_COLUMNS描述表列细节,而SYS_FIELDS则涉及索引中的列分布。这些信息对于数据库恢复至关重要。" 127040354,14781890,Vue Router 深入解析与实战,"['Vue.js', '前端开发', '路由']
摘要由CSDN通过智能技术生成

在以前的文章中说过mysql的数据字典的恢复(使用工具直接抽取MySQL数据字典,缺少SYS_FIELDS表),主要的数据字典有一下几个,在本文中主要对这些数据字典的意义进行一些讲解,为大家更深一步了解mysql恢复处理思路

MySQL恢复字典表

mysql> show tables;

+----------------+

| Tables_in_test |

+----------------+

| SYS_COLUMNS |

| SYS_FIELDS |

| SYS_INDEXES |

| SYS_TABLES |

+----------------+

4 rows in set (0.00 sec)

SYS_TABLES

这个表是mysql恢复的最核心的表之一,主要是记录数据库在InnoDB中表的信息。它默认写在InnoDB的index_ids为1的里面,它的根页在8号page上,他的主要列结构为:

mysql> desc SYS_TABLES;

+--------------+---------------------+------+-----+---------+-------+

| Field | Type | Null | Key | Default | Extra |

+--------------+---------------------+------+-----+---------+-------+

| NAME | varchar(255) | NO | PRI | | |

| ID | bigint(20) unsigned | NO | | 0 | |

| N_COLS | int(10) | YES | | NULL | |

| TYPE | int(10) unsigned | YES | | NULL | |

| MIX_ID | bigint(20) unsigned | YES | | NULL | |

| MIX_LEN | int(10) unsigned | YES | | NULL | |

| CLUSTER_NAME | varchar(255) | YES | | NULL | |

| SPACE | int(10) unsigned | YES | | NULL | |

+--------------+---------------------+------+-----+---------+-------+

8 rows in set (0.00 sec)

NAME:顾名思义,就是表的名字,但是注意他记录的格式是db/table,例如:xifenfei/zx_users,表示为xifenfei数据库中的zx_users表

ID:表的编号

N_COLS:表一共包含的列的数量

TYPE, MIX_ID, MIX_LEN 和 CLUSTER_NAME列,对于数据库恢复无任何意义不做描述

SPACE:表空间的标示列. 例如: ibdata1 是 SPACE 0, ibdata2 是 SPACE 1, 每一个 ibd 文件都有自己的表空间标示.

SYS_INDEXES

这个也是mysql恢复的最核心表之一,主要是记录InnoDB的index信息,它默认InnoDB的index_ids为3的里面,他的主要结构为:

mysql> desc SYS_INDEXES;

+----------+---------------------+------+-----+---------+-------+

| Field | Type | Null | Key | Default | Extra |

+----------+---------------------+------+-----+---------+-------+

| TABLE_ID | bigint(20) unsigned | NO | PRI | 0 | |

| ID | bigint(20) unsigned | NO | PRI | 0 | |

| NAME | varchar(120) | YES | | NULL | |

| N_FIELDS | int(10) unsigned | YES | | NULL | |

| TYPE | int(10) unsigned | YES | | NULL | |

| SPACE | int(10) unsigned | YES | | NULL | |

| PAGE_NO | int(10) unsigned | YES | | NULL | |

+----------+---------------------+------+-----+---------+-------+

7 rows in set (0.00 sec)

TABLE_ID:表标示列,为SYS_TABLES.ID

ID:为InnoDB中的index的编号,这个在恢复中非常重要,恢复之时需要根据这个去定位具体的文件

NAME:主要表的index的名字,有PRIMARY 和 普通列的index信息,一般恢复之时我们选择PRIMARY

N_FIELDS:表名index包含列的数量,在mysql恢复中不重要

TYPE:恢复之中使用不到该列,不做说明

PAGE:用途等同SYS_TABLES.SPACE

PAGE_NO:标示为每个index的root page的page号,关于index中的page结构如下图所示

2fde220ee19b77aad448cae510e7459a.png

SYS_COLUMNS

这个表主要记录数据库中表的列的情况,它存储在index_id 2中.主要用它来确定需要恢复表的列的情况,如果你知道完全的列结构,该表不是MySQL恢复所必须的,它的主要结构为:

mysql> desc SYS_COLUMNS;

+----------+---------------------+------+-----+---------+-------+

| Field | Type | Null | Key | Default | Extra |

+----------+---------------------+------+-----+---------+-------+

| TABLE_ID | bigint(20) unsigned | NO | PRI | NULL | |

| POS | int(10) unsigned | NO | PRI | NULL | |

| NAME | varchar(255) | YES | | NULL | |

| MTYPE | int(10) unsigned | YES | | NULL | |

| PRTYPE | int(10) unsigned | YES | | NULL | |

| LEN | int(10) unsigned | YES | | NULL | |

| PREC | int(10) unsigned | YES | | NULL | |

+----------+---------------------+------+-----+---------+-------+

7 rows in set (0.00 sec)

TABLE_ID:表标示列,为SYS_TABLES.ID

POS:该列所在表中的位置,该值从0开始

NAME:列的名字

MTYPE 和 PRTYPE:主要是为了记录列的类型,出现此类问题主要是由于InnoDB最初并不是为MySQL而设计,到了后面为更好支持MySQL,因此出现了两种情况.

LEN:列的长度.这个需要注意编码,比如数据库是utf8编码,定义的varchar(10),实际该处长度显示为30,因为每个除英文外的字符编码为3个byte.

PREC:有些特殊类型中,列的精确度定义

SYS_FIELDS

记录所有index的列的分布信息,它存储在index_id 4中,该表不是MySQL恢复所必须的,它的主要结构为:

mysql> desc SYS_FIELDS;

+----------+---------------------+------+-----+---------+-------+

| Field | Type | Null | Key | Default | Extra |

+----------+---------------------+------+-----+---------+-------+

| INDEX_ID | bigint(20) unsigned | NO | PRI | NULL | |

| POS | int(10) unsigned | NO | PRI | NULL | |

| COL_NAME | varchar(255) | YES | | NULL | |

+----------+---------------------+------+-----+---------+-------+

3 rows in set (0.00 sec)

INDEX_ID:index的标志,等同SYS_INDEXES.ID

POS:列在index中的位置,从0开始

COL_NAME:列的名称

通过上述相关表和列,然后结合MySQL相关恢复工具,就可以从底层在InnoDB出现问题,或者误操作之时提供恢复处理.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值