根据我上一篇的单个数据恢复;table名为result;result有1.3G,一年半的数据,无法恢复,焦虑好几天
alter table result diascrd tablespace;
alter table result import tablespace;
执行import语句时报错error code 1815:Internal error:cannt reset LSNs in table result :Data structure corruption
这应该说我的result 表结构已破坏,我进入.err文件查看具体信息,说result table的多少页偏移量多少的数据已损坏,不可以按现有的方法恢复已破损的.ibd文件;
之后我找到一个方法恢复了我的数据,真是太好了,苍天待我不薄啊!
恢复步骤:
先将自己本地mysql data能正常开启的data文件夹复制一份,起名原始data;操作到data文件夹(备份很重要)
1、将old_data中关于schem文件夹拷贝到本地mysql data下,(只需要将单个result .frm .ibd文件拷贝就好),再加上old_data根目录下的ibdata1,ibtmp1,auto.cnf拷贝覆盖到现有文件中;
2、将现有根目录下的ib_logfile0,ib_logfile1删除掉;
3、将本地my.min文件中在[mysqld]下新增一句innodb_force_recovery=4 或者 6,然后尝试启动mysqld;(强制恢复数据,跳过有问题的数据内容)
4、这时候数据库只能进行查询select语句,可以看到数据已恢复;立马用mysqldump将数据导出到本地,然后导入服务器中;
麻烦:本地的数据是出来了,但是不能更改新增,去断掉mysql服务出现错误,导致mysql启动按钮为灰色,无法启动,
解决:用DOM执行net start mysql57(注意mysql名,一定要正确,看mysql服务设定名),报错服务正在启动或停止中;进入工作管理员在进程中将mysql.exe停止工作即可;之后就可以在服务中看到mysql服务右键开始键可以点击,
因为你将有问题的table .itable1覆盖过来,将innodb_force_recovery 删除掉,已经mysql不能正确开启;(开启又立马断开服务);你要讲指引路径datadir 改为原始data;这样你的mysql才可以正常开启。
1.3G的数据导出导入会有点慢,而且索引页没有,不要去新增数据,因为innodb_force_recovery 的设定,这能查询,不能更改新增,只能将数据直接导入服务器数据库,再去添加索引;