mysql repair table导致数据丢失的解决方法

发布时间:2019-08-28编辑:脚本学堂
在本地测试机上,MySQL 5.1.43,MyISAM引擎,执行repair table的时候,导致数据丢失,特此记录,以前在MySQL5.0.32版本也遇到过同样的问题,所以在repair table前一定要备份。

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

这个也是MySQL官方承认的bug,
http://bugs.mysql.com/bug.php?id=10437
http://bugs.mysql.com/bug.php?id=1804

mysql手册上也指出来了:
MySQL5.0 和MySQL5.1 ,

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

使用myisamchk --safe-recover

牛人给的推荐:OPTIMIZE LOCAL TABLE tablename; 这个命令的好处是对MyISAM和innodb都起作用。

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