mysql恢复单个数据,error code 1815

根据我上一篇的单个数据恢复;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 的设定,这能查询,不能更改新增,只能将数据直接导入服务器数据库,再去添加索引;

 

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值