首页 > 数据库 > mysql教程 > MySQL MyISAM表结构的恢复_MySQL

MySQL MyISAM表结构的恢复_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-06-01 13:35:04
原创
1059 人浏览过

bitsCN.com

MySQL MyISAM表结构的恢复

 

MySQL MyISAM表结构的恢复方法是怎样的呢?这是很多人都提过的问题,下面就为您详细介绍MySQL MyISAM表结构的恢复方法,供您参考。

MySQL MyISAM类型的表恢复相对比较简单。

同样先假定需要恢复的表的FRM文件为test_myisam.frm,表结构为

mysql> create table test_myisam  

    -> (A int(11) default NULL,  

    -> B varchar(30) default NULL,  

    -> C date default NULL) engine=myisam;  

Query OK, 0 rows affected (0.05 sec)  

 

恢复过程如下:

1. 直接将test_myisam.frm拷贝到正常数据库对应的数据目录下。这时测试

mysql> show tables;  

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

| Tables_in_aa |  

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

| test_innodb |  

| test_myisam |  

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

3 rows in set (0.00 sec)  

 

mysql> desc test_myisam;  

ERROR 1017 (HY000): Can't find file: 'test_myisam' (errno: 2)  

 

发现只能通过show tables命令看见表名,但是表结构还是没有恢复,desc命令报错。

2. 在与test_myisam.frm同一目录建立以下2个文件,文件内容可以为空:

test_myisam.MYD test_myisam.MYI

3. 在MYSQL命令行使用MYSQL本身的数据表恢复命令repair命令恢复表,如下:

mysql> repair table test_myisam USE_FRM;  

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

| Table           | Op     | Msg_type | Msg_text |  

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

| aa.test_myisam | repair | status   | OK       |  

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

1 row in set (0.00 sec)  

 

根据结果可以知道,恢复命令执行成功,下边用desc命令测试下:

mysql> desc test_myisam;  

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

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

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

| A     | int(11)     | YES |     | NULL    |       |  

| B     | varchar(30) | YES |     | NULL    |       |  

| C     | date        | YES |     | NULL    |       |  

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

3 rows in set (0.02 sec)  

 

果然恢复成功了。

bitsCN.com
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板