技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> MySQL --> MySQL异常恢复之恢复数据字典表讲解

MySQL异常恢复之恢复数据字典表讲解

浏览:1690次  出处信息


   在以前的文章中说过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结构如下图所示

   Bplustree


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出现问题,或者误操作之时提供恢复处理.

建议继续学习:

  1. 用 LD_PRELOAD 挽救被误删的 libc.so.6    (阅读:4163)
  2. MySQL从压缩文件恢复数据    (阅读:3699)
  3. 参数_smon_internal_errlimit与数据库恢复    (阅读:3196)
  4. MySQL 备份和其恢复机制原理简述    (阅读:3133)
  5. 用bin日志中恢复MySQL数据库    (阅读:2688)
  6. 用CloneZilla制作紧急恢复分区    (阅读:2642)
  7. Zmanda让MySQL的备份与恢复更加方便快捷灵活    (阅读:2331)
  8. 当logfile被误删除后    (阅读:2189)
  9. EXT文件系统误删除数据恢复指南    (阅读:2187)
  10. Oracle数据库恢复:存储故障导致的数据损坏    (阅读:2023)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1