mysql修复数据表

myisamchk 修复工具 MySQL 自带了专门用户数据表检查和修复的工具——myisamchk,当 repair.php 多次修复均无法成功时,可以在服务器终端使用 myisamchk 进行修复。在 MySQL 的程序文件目录(见《数据备份与恢复》中的说明)可以找到这个工具。

常用的修复命令为 myisamchk -r 数据文件目录/数据表名.MYI,如果 -r 参数不能奏效,可以先把数据文件备份(备份可使用直接文件复制的方式,详见《数据备份与恢复》中的说明)后使用 -o 参数,如果-o还不可以的话,就使用-f参数,如果还是无法修复,只有使用你的备份文件来恢复数据了!什么??你没有备份文件那你就坐到那里哭吧!!开个玩笑,但是网站及时的做备份确实是很重要的,尤其当有一定的规模以后,建议每天都做备份!! 下面说一下具体的步骤: 1.[attach]33120[/attach] 2.更改当前目录到mysql/bin下面,一般情况下只有在这个下面才能运行myisamchk命令 [attach]33121[/attach] 3.修复的结果,如果修复后的情况都如下图所示的话,你就可以了,成功了,继续开启你的网站,运行吧!! [attach]33122[/attach] 4.别忘了启动你的mysql,要不你的网站还是运行不起来. [attach]33123[/attach] ps:下面给的一个是linux下面的修复方法,和上面的基本相同.只是linux下面关闭和启动mysql的方法和windows的不同.一般情况下linux用

/etc/init.d/mysql stop service mysqld stop /etc/init.d/mysql start service mysqld start

来关闭和启动mysql [attach]33125[/attach]

另外 MySQL 官方文档中还提供了针对上面操作均无法奏效时的特殊办法,如先清空重建数据表,然后再用备份的数据文件覆盖等,这种特别复杂的情况用户通常不会碰到,因此这里不再做过于深入的研究。

在服务器终端使用 myisamchk 进行修复的详细步骤如下:在运行里面输入cmd,进入命令行 改变路径到你装mysql的bin目录下面,并运行myisamchk,命令如图所示

[img]http://kb.discuz.net/images/1/18/Myisamchk_Fkge3aypKMey.jpg[/img]
运行结果如图所示表明修复成功,可以开启论坛了!

[img]http://kb.discuz.net/images/a/aa/Theresult_BXmCwpZkj538.jpg[/img]
启动mysql,整个修复完成

[img]http://kb.discuz.net/images/9/92/Startmysql_CzOGSvzciTzc.jpg[/img]
linux下面和在windows下面是一样的.首先要停掉mysql,然后运行myisamchk修复就可以了如图:
[img]http://kb.discuz.net/images/b/b1/Linux_AMlD3NCxELqb.jpg[/img]
三:数据表经常性损坏的解决方法首先请确认在服务器硬件不存在问题(如内存工作不稳定、散热条件不好等),且使用中的操作系统版本也没有相关的 BUG 报告或升级补丁。这种情况下,如果数据库仍出现经常性的损坏,请检查是否 MySQL 的编译方式或参数存在问题。通常情况下使用官方提供的编译好的版本是比较稳定的,可以长期使用。如果您钟爱自行编译相关程序,请确认您的语言编译器(如 gcc)和配置的相关参数没有导致不稳定的因素。同时,磁盘分区满也可能是导致数据表经常性损坏的原因。网上提供了一些问题的处理方法(英文),需要时可多参考,并针对您的具体服务器环境制定解决方案。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值