当前位置:  数据库>mysql

教您修复mysql数据库的方法

    来源: 互联网  发布时间:2014-10-15

    本文导语:  会mysql的朋友都知道mysql在长时间使用过后数据库会出现一些问题,这就需要快速修复损坏mysql数据库以方便我们的工作和学习。下面小编为大家下面介绍两种快速检修 MySQL 数据库的方法。 本人常用这样的代码,直接放到mysql数...

会mysql的朋友都知道mysql在长时间使用过后数据库会出现一些问题,这就需要快速修复损坏mysql数据库以方便我们的工作和学习。下面小编为大家下面介绍两种快速检修 MySQL 数据库的方法。

本人常用这样的代码,直接放到mysql数据库目录里面

代码如下:

cmd /k myisamchk -r jb51_tablename

jb51_tablename是jb51_tablename.MYD的名称。运行以下就可以了。

有的时候因为掉电或者其他原因导致数据库损坏,我们可以使用mysql自带的mysqlcheck命令来快速修复所有的数据库或者特定的数据库;例如
检查优化并修复所有的数据库用:

1.先在运行中输入CMD,启动命令行.

2.进入Mysql的Bin目录:E:Program FilesMySQLMySQL Server 5.0bin,如果不知道如何进入别的目录,就要参考网上的资料补习基础知识了.
常见方式:
运行 E:
运行 CD "E:Program FilesMySQLMySQL Server 5.0bin"

3.运行:mysqlcheck -A -o -r -uroot -p888888
注意,将888888改成你自己的root用户密码

mysql.columns_priv                 OK
mysql.db                      OK
mysql.func                     OK
mysql.help_category                OK
mysql.help_keyword                 OK
mysql.help_relation                OK
mysql.help_topic                  OK
mysql.host                     OK
mysql.tables_priv                 OK
mysql.time_zone                  OK
mysql.time_zone_leap_second            OK
mysql.time_zone_name                OK
mysql.time_zone_transition             OK
mysql.time_zone_transition_type          OK
mysql.user                     OK
......
......
......

注意!


在修复过程中,如果看到有error的提示,表明这个表是坏的,无法修复的,对于含有坏表的的数据库,您只能删除它,或停止它,不然会影响整个Mysql的稳定,造成mysql自动停止.(提示"The storage engine for the table doesn't support repair"的表不需要处理)


如果修复太快看不到结果,可以运行
mysqlcheck -A -o -r -uroot -p888888 >>C:test.txt

运行后打开test.txt就可以看到了. 
  
1、myisamchk

  使用 myisamchk 必须暂时停止 MySQL 服务器。例如,我们要检修 discuz 数据库。执行以下操作:

代码如下:

  # service mysql stop (停止 MySQL );
  # myisamchk -r /数据库文件的绝对路径/*MYI
  # service mysql start


  myisamchk 会自动检查并修复数据表中的索引错误。

2、mysqlcheck

  使用 mysqlcheck 无需停止 MySQL ,可以进行热修复。操作步骤如下:
  
># mysqlcheck -r discuz.*

小编提醒:无论是 myisamchk 还是 mysqlcheck ,一般情况下不要使用 -f 强制修复,-f 参数会在遇到一般修复无法成功的时候删除部分出错数据以尝试修复。所以,不到万不得已不要使用 -f。

以下是补充:

一张损坏的表的症状通常是查询意外中断并且你能看到例如这些错误:

◆ “tbl_name.frm”被锁定不能改变。

◆ 不能找到文件“tbl_name.MYI”(Errcode :### )。

◆ 从表处理器的得到错误###(此时,错误135是一个例外)。

◆ 意外的文件结束。

◆ 记录文件被毁坏。

在这些情况下,你必须修复表。表的修复是一项非常困难的工作,很多情况下令人束手无策。然而,有一些常规的知道思想和过程,可以遵循它们来增加修正表的机会。通常,开始是可以用最快的修复方法,看看能否袖珍故障。如果发现不成功,可以逐步升级到更彻底的但更慢的修复方法。如果仍旧难以修复,就应该从备份中恢复了。在上一章已经详细介绍了这一部分内容。

简单安全的修复

为了修复一个表执行下列步骤:

◆ 首先,用--recover,-r选项修正表,并且用--quick,-q选项,来只根据索引文件的内容进行恢复。这样不接触数据文件来修复索引文件。(-r意味着“恢复模式”)

myisamchk -r -q tbl_name
isamchk -r -q tbl_name


◆ 如果问题仍旧存在,则忽略--quick选项,允许修复程序修改数据文件,因为这可能存在问题。下面的命令将从数据文件中删除不正确的记录和已被删除的记录并重建索引文件:

myisamchk -r tbl_name
isamchk -r tbl_name


◆ 如果前面的步骤失败,使用。安全恢复模式使用一个老的恢复方法,处理常规恢复模式不行的少数情况(但是更慢)。

myisamchk --safe-recover tbl_name
isamchk --safe-recover tbl_name


困难的修理

如果在索引文件的第一个16K块被破坏,或包含不正确的信息,或如果索引文件丢失,你只应该到这个阶段 。在这种情况下,创建一个新的索引文件是必要的。按如下这样的步骤做:

◆ 定位到包含崩溃表的数据库目录中

◆ 把数据文件移更安全的地方。

◆ 使用表描述文件创建新的(空)数据和索引文件:

shell> mysql db_namemysql> DELETE FROM tbl_name;mysql> quit


上述语句将重新创建新的空表,并使用表的的描述文件tbl_name.frm重新生成新的数据和索引文件。

◆ 将老的数据文件拷贝到新创建的数据文件之中。(不要只是将老文件移回新文件之中;你要保留一个副本以防某些东西出错。)

◆ 在使用标准的修复方法。现在myisamchk -r -q应该工作了。(这不应该是一个无限循环)。

如果你拥有表的备份文件,那么一切过程就容易的多。从备份文件中可以恢复表的描述文件,然后在检查表,有可能还要继续使用标准的修复方法,应该纠可以解决问题了。

非常困难的修复

只有描述文件也破坏了,你才应该到达这个阶段。这应该从未发生过,因为在表被创建以后,描述文件就不再改变了。

从一个备份恢复描述文件并且回到阶段2。你也可以恢复索引文件并且回到阶段1。对于后者,你应该用myisamchk -r启动。

如果因为某种原因,数据的备份文件丢失或者没有备份文件,但是你还记得建立表的CREATE TABLE语句,那么太好了,这样还是可以恢复索引文件:

◆ 定位到包含崩溃表的数据库目录中

◆ 把数据文件移更安全的地方。再把数据库目录中的对应的目录删去.。

◆ 调用mysql并发复CREATE TABLE语句建立该表。

◆ 退出mysql,将原始的数据文件和索引文件移回到数据库的目录中,替换刚才新建的文件。

◆ 然后回到阶段2,修复表。也可以只移回数据文件,这样保留新的描述和索引文件,然后回到阶段1,继续用标准的方法修复表。


    
 
 

您可能感兴趣的文章:

  • 快速修复损坏的MySQL数据库
  • 修复断电等损坏的SQL 数据库
  • SQL Server数据库的修复SQL语句
  • 使用shell检查并修复mysql数据库表的脚本
  • 检查并修复mysql数据库表的具体方法
  • SQLServer 数据库故障修复顶级技巧之一
  • MySQL数据库表修复 MyISAM
  • 巧用Oracle8i来修复数据库坏块的简单方法
  • 只有mdf文件的数据库附加失败的修复方法分享(置疑、只读)
  • Asp.net在线备份、压缩和修复Access数据库示例代码
  • mysql中优化和修复数据库工具mysqlcheck详细介绍
  • asp.net在线备份、压缩与修复access数据库
  • sql注入数据库修复的两种实例方法
  • MySQL数据库INNODB表损坏修复处理过程分享
  • MySQL数据库修复方法(MyISAM/InnoDB)
  • mysql修复数据表的命令方法
  • phpmyadmin显示MySQL数据表“使用中” 修复后依然无效的解决方法
  • MSSQL木马修复,中木马后的处理方法
  • jquery的clone方法应用于textarea和select的bug修复
  • ThinkPHP框架任意代码执行漏洞的利用及其修复方法
  • subsonic3.0插件更新字符串过长引发的异常修复方法
  • MYSQL错误:Can’t open file: ‘×××.MYI’ (errno: 145)修复方法
  • python正则表达式修复网站文章字体不统一的解决方法
  • jquery clone方法bug修复
  • 快速修复Oracle参数文件的另类方法
  • MYSQL数据表损坏的原因分析和修复方法小结(推荐)
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • PHP 'ext/soap/php_xml.c'不完整修复存在多个任意文件泄露漏洞
  • redhat内核镜像丢失,如何在修复模式下修复???
  • 请问出现fstab文件丢失该怎么修复呀?
  • 怎样修复启动盘?
  • pcap文件修复工具 pcapfix
  • linux下如何修复破损的普通文件!?
  • 硬盘出现坏区啊!!!如何修复???
  • 怎么使用光盘修复Solaris 10 啊
  • GRUB修复
  • 图形化Grub/Grub2修复工具 Rescatux
  • 如何修复被破坏的UNIX操作系统
  • 检查修复LINUX文件系统
  • 如何修复
  • 怎样修复linux?
  • 请教 stop: Unknown instance 错误是什么意思,怎么修复?
  • Linux下当一个文件系统受到破坏时,如何检查并修复系统?
  • 【菜鸟求助】重装win7了,如何修复grub和debian6.0的引导
  • 如何把坏扇区修复了的硬盘再还她本来面貌
  • 磁盘修复工具 TestDisk
  • 急!我的linux中的所有文件被我误删除了,请问怎么才能修复它?
  • 磁盘修复工具 gpart


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3