mysql数据恢复:.frm和.ibd,恢复表结构和数据

mysql数据恢复:.frm和.ibd,恢复表结构和数据


相关内容原文地址:

CSDN:她说巷尾的樱花开了:mysql根据.frm和.ibd文件恢复表结构和数据

博客园:丹江流:Mysql 通过frm&ibd 恢复数据


通过这次恢复数据发现,docker真的是方便,如果使用mysql客户端恢复,关闭,启动服务一直。使用docker容器启动mysql,很好 调试。

一、恢复表结构

  1. 通过navicat新建数据库,在新建的数据库中,随意创建一张表,但是这张表的名字要和你要恢复的.frm或者.ibd一致,在此我的.frm与.ibd文件为songlyric.frm与songlyric.ibd因此我的创建表语句为:
create table songlyric(id int);
  1. 在执行上面的创建表语句之后,使用net stop mysql关闭数据库服务(我使用的是Docker容器发布的mysql服务,则通过docker stop imageId关闭mysql数据即可),然后用需要恢复的songlyric.frm覆盖这个新建的wangyi数据库的songlyric表的物理文件songlyric.frm,接着对配置文件(my.ini,采用docker容器启动mysql,需要将mysql的配置文件挂载出来。-v /conf:/etc/mysql/conf.d)设置innodb_force_recovery = 6,然后使用net start mysql(docker启动mysql docker start mysql)启动服务,接着使用:desc songlyric查看该表结构,会出现下面错误信息:

    mysql数据恢复:.frm和.ibd,恢复表结构和数据
  2. 针对这个问题,我们可以通过查看mysql的日志文件来解决,查看mysql安装目录下的data文件夹里面.err结尾的文件,你会发现出现下面所示的错误信息:[Warning] InnoDB: Table wangyi/songlyric contains 1 user defined columns in InnoDB, but 6 columns in MySQL.原来是因为,我们要恢复的表有6个字段,而我们在创建表的时候只创建了1个字段。

解决方案:删除songlyric表重新创建一个包含6个字段的表,具体这6个字段是什么不用管的。具体执行过程为使用net stop mysql停掉服务,然后在配置文件my.ini中将innodb_force_recovery = 6注释掉(#或;均可),再net start mysql启动服务。接着在控制台先执行drop table songlyric;删除表,再执行创建表语句,我执行的是下面的创建表语句:create table songlyric(id int,id1 int,id2 int,id3 int,id4 int,id5 int);

紧接着按照前面的方式,使用net stop mysql关闭数据库服务,然后用需要恢复的songlyric.frm覆盖这个新建的wangyi数据库的songlyric表的物理文件songlyric.frm,接着对配置文件(my.ini)设置innodb_force_recovery = 6,然后使用net start mysql启动服务,接着使用:desc songlyric查看该表结构,输出下面结果表示恢复表结构成功:

mysql数据恢复:.frm和.ibd,恢复表结构和数据

二、恢复表数据

  1. 恢复表数据需要首先将原先的.ibd文件与原先的.frm文件解除绑定,具体就是在控制台执行下面命令:

    alter table songlyric discard tablespace;
  2. 接着执行net stop mysql停掉服务,将需要恢复的songlyric.ibd文件覆盖这个新建的wangyi数据库的songlyric表的物理文件songlyric.ibd,执行net start mysql开启服务。
  3. 将复制过来的songlyric.ibd文件与songlyric.frm文件发生联系。具体执行下面命令:

    alter table songlyric import tablespace;
  4. 这时候通过navicat查看数据表,你会发现数据已经成功恢复。
上一篇:CSP2021模拟赛:T2-Excel计数法


下一篇:AJPFX总结mysql复制表结构,表数据