repair table导致数据丢失

       前天在本地测试机上,MySQL 5.1.43,MyISAM引擎,执行repair table的时候,导致数据丢失,特此记录,以前在MySQL5.0.32版本也遇到过同样的问题,所以在repair table前一定要备份。

       在执行repair table的前一晚,刚看了“宇航员的妻子”的电影,虽然是个烂片,但是其中的一句话印象很深刻:“太空总署告诉我,一定要有备份”,外行人都知道的简单的道理,我却没有做到,以此谨记。

       这个也是MySQL官方承认的bug,

http://bugs.mysql.com/bug.php?id=10437,

http://bugs.mysql.com/bug.php?id=1804

MySQL手册上也指出来了:

MySQL5.0MySQL5.1

遇到同样的问题,我们该怎么规避这件事情呢?

使用myisamchk --safe-recover

还有一个牛人给我推荐了:OPTIMIZE LOCAL TABLE tablename; 这个命令的好处是对MyISAM和INNODB都起作用,呵呵,下次试试

经过测试MyISAM表遭到破坏后OPTIMIZE LOCAL TABLE tablename;是修复不了的,还是使用myisamchk --safe-recover 当然别忘记备份!

转载于:https://www.cnblogs.com/sunss/archive/2011/05/16/2047493.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值