今天吐血向大家分享下mysql通过.frm和.ibd文件恢复数据的方法,因为之前电脑换系统的原因,忘记备份数据库,最后只能通过恢复工具找到数据库的.frm和.ibd文件,至于这两类文件,可以通过winhex软件查看,该软件的破解版传送门:http://download.csdn.net/download/hzw19920329/9987735,为了恢复数据,今天踩了不少坑,下面把我成功恢复的过程分享给大家;
整个恢复过程其实可以总结为下面几步:
(1):恢复表结构
(2):复制出来创建表的sql语句
(3):恢复表数据(在恢复表数据的时候,首先需要解除当前创建的表与默认生成的.ibd文件间的关系,接着将要恢复数据表的.ibd文件与当前创建的表联系起来即可)
恢复表结构
首先创建一个数据库,可以通过navicat来创建,创建截图为:
使用当前创建的数据库:use wangyi
随意创建一张表,但是这张表的名字要和你要恢复的.frm或者.ibd一致,在此我的.frm与.ibd文件为songlyric.frm与songlyric.ibd因此我的创建表语句为:
create table songlyric(id int);
在执行上面的创建表语句之后,使用net stop mysql关闭数据库服务,然后用需要恢复的songlyric.frm覆盖这个新建的wangyi数据库的songlyric表的物理文件songlyric.frm,接着对配置文件(my.