关闭

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

标签: PHPmysql数据表损坏修复
2392人阅读 评论(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)和配置的相关参数没有导致不稳定的因素。同时,磁盘分区满也可能是导致数据表经常性损坏的原因。网上提供了一些问题的处理方法(英文),需要时可多参考,并针对您的具体服务器环境制定解决方案。
0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

MYSQL数据表损坏的原因分析和修复方法小结

1.表损坏的原因分析  以下原因是导致mysql 表毁坏的常见原因:  1、 服务器突然断电导致数据文件损坏。  2、 强制关机,没有先关闭mysql 服务。  3、 mysqld 进程在写表时被杀掉。  4、 使用myisamch...
  • cplasfc3
  • cplasfc3
  • 2016-11-11 15:25
  • 2433

MySQL表损坏修复解决方案

数据损坏原因MySQL表损坏一般是数据损坏,引起损坏的原因可能是由于磁盘损坏、系统崩溃或者MySQL服务器被崩溃等外部原因。例如有人使用kill -9终止进程,导致MySQL进程未能正常关闭,那么就很有可能导致数据损坏。 对于不同的引擎,数据损坏修复的方式不一样,作为一般情况可以尝试使用CHECK...
  • qq_35440678
  • qq_35440678
  • 2017-03-04 10:18
  • 1929

Sql Server 2008 R2数据库损坏修复成功案例

2016.4月 青岛某连锁店使用的SQL 2008R2数据库,客户在正常使用中突然服务器断电导致的损坏,再次附加发现数据库报错不能正常运行,客户那边管理员自己尝试了修复以及重建日志但是故障依旧,后来发现自己解决不了,通过百度搜索,联系到我们进行处理。 我们的工程师具体查看了一下,数据库大小600M...
  • tongyuekeji123
  • tongyuekeji123
  • 2016-04-13 11:31
  • 3683

视频修复工具修复损坏avi视频文件

视频损坏该怎么办,用视频修复工具呀,但是这么多的数据恢复工具,到底哪款可以修复出我要的视频文件呢?   这应该是很多遇到视频损坏的客户都会遇到的问题,那么到底该怎么解决呢?   今天甲驭科技数据恢复中心小编给大家推荐一款合适的视频修复工具,让你用的放心,用的满意。   来自湖北十堰的王小姐通过...
  • qq_33983359
  • qq_33983359
  • 2016-05-06 17:38
  • 1477

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

由于临时断电,使用kill -9中止MySQL服务进程,所有的这些都可能会毁坏MySQL的数据文件。如果在被干扰时,服务正在改变文件,文件可能会留下错误的或不一致的状态。因为这样的毁坏有时是不容易被发现的,当你发现这个错误时可能是很久以后的事了。于是,当你发现这个问题时,也许所有的备份都有...
  • qq_33983359
  • qq_33983359
  • 2016-03-01 16:20
  • 3465

修复断电损坏的MySQL数据表

遇到报错:Error: Table ‘p’ is marked as crashed and should be repaired Caused by: java.sql.SQLException: Table ‘表名’ is marked as crashed and should be repa...
  • qq_15969757
  • qq_15969757
  • 2017-04-12 10:58
  • 268

修复 SQLite 数据库文件

目 录 第1章 说明    1 1 下载SQLite Tools    1 2 运行    2   第1...
  • Hanford
  • Hanford
  • 2016-12-01 17:29
  • 723

视频文件损坏怎么修复

不少用户在使用机器拍摄视频文件时,难免遇到文件损坏而无法正常打开的问题。对于绝大多数文件类型来说,对于视频文件来说,我们可以尝试对其进行修复。因为视频文件中的影像若缺少了个别帧,效果仍然可以接受。更何况绝大多数出现问题的视频文件,只是文件头信息或者索引信息不完整,而这些问题几乎都能被完全修复过来。
  • MP4DataHelp
  • MP4DataHelp
  • 2017-07-27 08:19
  • 1762

hadoop edits 文件损坏修复办法

前段时间公司hadoop集群宕机,发现是namenode 磁盘满了。。清理出部分空间后,重启集群时,重启失败。 又发现集群Secondary namenode 服务也恰恰坏掉,导致所有的操作log持续写入edits.new 文件,等集群宕机的时候文件大小已经达到了丧心病狂的70G+..重启集群报错...
  • wisgood
  • wisgood
  • 2015-07-26 10:40
  • 991

如何修复破损的录音文件(m4a)

你的录音文件损坏了吗?你可以自己修复!这篇文章里,我将告诉你所需的步骤。 录音文件的拓展名为“m4a”. 这种音频数据是用AAC格式编码的,然后封装在了MPEG4文件中。 在安卓系统的QuickVoice等程序录制的话,文件拓展名也可能是mp4或3gp。 如果文件头的某些部分丢失了正确的信息,m4a...
  • dj0379
  • dj0379
  • 2016-11-03 13:14
  • 4471
    个人资料
    • 访问:1034833次
    • 积分:13782
    • 等级:
    • 排名:第1074名
    • 原创:323篇
    • 转载:159篇
    • 译文:0篇
    • 评论:19条
    最新评论