数据表损坏的修复方法(终极完美版!!!!!)

标签: PHP mysql 数据表损坏修复
2430人阅读 评论(0) 收藏 举报
分类:
由于 MySQL 本身的读写及锁定机制等方面的原因,与一些其他数据库软件一样,在特殊情况下的极为频繁读写时,或在服务器掉电、死机等情况下,相关的数据文件可能会发生被损坏的情况,通常可以采用以下的方式加以解决。 

一:repair.php 修复工具
Discuz! 自带了一个使用 PHP 编写的数据表修复工具 repair.php,虚拟主机用户也可使用。该工具位于软件包的 ./utilities 目录中,使用时需要上传到服务器上论坛目录(注意不要连 ./utilities 目录一起上传,否则无法运行),  
在浏览器运行后点击下面的链接即可 

修复以后如果出现下面的画面表示修复成功!!!
 
这个工具能修复大多数常见的数据库错误,尤其是错误号为 126、127 的错误,对 145 错误也可修复,同时能对数据表在修复之后进行优化。如果一次修复不成功,可以尝试多次,或将数据库重启后再试。 



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

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

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

三:数据表经常性损坏的解决方法

--------------------------------------------------------------------------------

首先请确认在服务器硬件不存在问题(如内存工作不稳定、散热条件不好等),且使用中的操作系统版本也没有相关的 BUG 报告或升级补丁。这种情况下,如果数据库仍出现经常性的损坏,请检查是否 MySQL 的编译方式或参数存在问题。通常情况下使用官方提供的编译好的版本是比较稳定的,可以长期使用。如果您钟爱自行编译相关程序,请确认您的语言编译器(如 gcc)和配置的相关参数没有导致不稳定的因素。同时,磁盘分区满也可能是导致数据表经常性损坏的原因。网上提供了一些问题的处理方法(英文),需要时可多参考,并针对您的具体服务器环境制定解决方案。
查看评论

EJB设计模式(第二版)之Message Facade

message facade 一个ejb客户端想要在一个环境的用例中调用多个ejb的 方法,并且不需要从服务器的立即的反映。 怎样才能让ejb客户端在一个事务中调用多个session bean或ent...
  • xxcc
  • xxcc
  • 2002-07-01 09:40:00
  • 1695

MySQL表损坏修复解决方案

数据损坏原因MySQL表损坏一般是数据损坏,引起损坏的原因可能是由于磁盘损坏、系统崩溃或者MySQL服务器被崩溃等外部原因。例如有人使用kill -9终止进程,导致MySQL进程未能正常关闭,那么就很...
  • qq_35440678
  • qq_35440678
  • 2017-03-04 10:18:09
  • 4074

涨姿势 | 如何修复硬盘,以及如何避免硬盘损坏

大数据文摘作品 作者:溘弭 对于硬盘损坏的原因,在网上搜索一下,就会发现各种各样的离奇损坏原因,比如读写时没有正常插拔、被狗咬坏、水和方便面调料撒到了上面,或者……被雷劈了。这些原因导致我...
  • dzJx2EOtaA24Adr
  • dzJx2EOtaA24Adr
  • 2017-11-30 00:00:00
  • 282

mysql数据库损坏修复方法介绍

由于临时断电,使用kill -9中止MySQL服务进程,所有的这些都可能会毁坏MySQL的数据文件。如果在被干扰时,服务正在改变文件,文件可能会留下错误的或不一致的状态。因为这样的毁坏有时是不容易被发...
  • qq_33983359
  • qq_33983359
  • 2016-03-01 16:20:56
  • 4593

postgres数据库坏块修复

转自:http://www.redgres.com/web/node/17   由于磁盘坏道或者是内存问题等硬件上的原因,有时候会导致数据库的数据文件的一些数据块的损坏,使得某些表不能正常访问,本文...
  • xqy1522
  • xqy1522
  • 2011-11-10 10:03:24
  • 1724

MySQL数据库INNODB 表损坏修复处理过程

MySQL数据库INNODB 表损坏修复处理过程 突然收到MySQL报警,从库的数据库挂了,一直在不停的重启,打开错误日志,发现有张表坏了。innodb表损坏不能通过repair table...
  • hzqhbc
  • hzqhbc
  • 2014-03-18 16:20:21
  • 2812

【mysql 因为断电表损坏修复方法】

1. check table 和 repair table   登陆MySQL终端:   1.> check table tabTest;   如果出现的结果说Status是OK,则不用修复,如...
  • Java_HYL
  • Java_HYL
  • 2014-04-02 15:40:26
  • 1120

MySQL损坏表修复(附录自动处理脚本)

Mysql 数据库 相信很多地方 都在用,在用的时候避免不了出现表的损坏,损坏之后我们就要修复。如果是单张表,我们使用命令轻易的修复。如果是其中 的一部分表那?最重要的是还不知道具体的那些表。如果 全...
  • risingsun001
  • risingsun001
  • 2016-02-25 15:41:38
  • 2541

详解:MySQL数据表损坏的正确修复方案

修复以损坏的MySQL数据表的实际操作在实际中是我们经常用到的,以下的文章主要是介绍正确修复以损坏的MySQL数据表的实际操作步骤,以下就是正文的介绍,希望会给你带来一些帮助在此方面。 于断电或非正常...
  • dyllove98
  • dyllove98
  • 2013-05-01 23:16:01
  • 687

mysql 从5.1升级到5.5.33 后 innodb 表出错 及 innodb表修复

从 .ibd 文件导出 innodb 表
  • gold2008
  • gold2008
  • 2013-09-15 10:36:58
  • 2201
    个人资料
    等级:
    访问量: 106万+
    积分: 1万+
    排名: 1101
    最新评论