mysql 数据库文件 表文件_mysql 从数据库源文件恢复表 (适用于 ibd 文件)

由于不知道什么原因,docker 上 mysql8.x的数据库打不开了,于是只好删掉重新创建;幸好当初mysql的数据库是存放在宿主机上的(详见 http://www.iamlintao.com/6680.html 的操作),所以只好从源文件开始恢复数据。

以下步骤只在 ibd 数据库文件下用过,并且是在知道表结构情况下进行的,请注意。

1. 先创建一个数据库,并且这个数据库必须是没有标和任何操作的,是一个纯粹的干净的数据库;

2.创建一个表结构,一定要和要恢复的表名是一样的,一定要是innodb引擎的,表结构要和原表一样;

3.以上两步完成后请执行如下命令,目的是清空改数据表的空间:

ALTER TABLE dt_tests_catagory DISCARD TABLESPACE;

4.从备份的文件中复制对应表的 .ibd 文件过来,只需要 .ibd 文件;

5.执行如下命令,导入表空间:

ALTER TABLE dt_tests_catagory IMPORT TABLESPACE;

6.查看数据库,如果不出意外数据已经回来了;

如果数据表的结构都不知道了,那要按照下面的步骤进行,然后再按照上面的流程执行:

1、先创建一个数据库,这个数据库必须是没有表和任何操作的。

2、创建一个表结构,和要恢复的表名是一样的。表里的字段无所谓。一定要是innodb引擎的。

CREATE TABLE `test`( `testID` bigint(20)) ENGINE=InnoDB DEFAULT CHARSET=utf8;

3、关闭mysql, service mysqld stop;

4、用需要恢复的frm文件覆盖刚新建的frm文件;

5、修改my.ini 里 innodb_force_recovery=1 , 如果不成修改为 2,3,4,5,6。

6、 启动mysql,service mysqld start;show create table test就能够看到表结构信息了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值