数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

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


发布日期:2020年08月25日
 
MySQL数据表损坏的正确修复方案

修复以损坏的MySQL数据表的实际操作在实际中是我们经常用到的以下的文章主要是介绍正确修复以损坏的MySQL数据表的实际操作步骤以下就是正文的介绍希望会给你带来一些帮助在此方面

于断电或非正常关机而导致MySQL(和PHP搭配之最佳组合)数据库出现错误是非常常见的问题有两种方法一种方法使用MySQL(和PHP搭配之最佳组合)的check table和repair table 的sql语句另一种方法是使用MySQL(和PHP搭配之最佳组合)提供的多个myisamchk isamchk数据检测恢复工具前者使用起来比较简便推荐使用

check table 和 repair table

登陆MySQL(和PHP搭配之最佳组合) 终端

MySQL(和PHP搭配之最佳组合) uxxxxx p dbname

> check table tabTest;

如果出现的结果说Status是OK则不用修复如果有Error可以用

> repair table tabTest;

进行修复修复之后可以在用check table命令来进行检查在新版本的phpMyAdmin里面也可以使用check/repair的功能

myisamchk isamchk

其中myisamchk适用于MYISAM类型的数据表而isamchk适用于ISAM类型的数据表这两条命令的主要参数相同一般新的系统都使用MYISAM作为缺省的数据表类型这里以myisamchk为例子进行说明当发现某个数据表出现问题时可以使用

myisamchk tablenameMYI

进行检测如果需要修复的话可以使用

myisamchk of tablenameMYI

关于myisamchk的详细参数说明可以参见它的使用帮助需要注意的时在进行修改时必须确保MySQL(和PHP搭配之最佳组合)服务器没有访问这个数据表保险的情况下是最好在进行检测时把MySQL(和PHP搭配之最佳组合)服务器Shutdown掉

另外可以把下面的命令放在你的rclocal里面启动MySQL(和PHP搭配之最佳组合)服务器前

[ x /tmp/MySQL(和PHP搭配之最佳组合)sock ] && /pathtochk/myisamchk of /DATA_DIR/*/*MYI

其中的/tmp/MySQL(和PHP搭配之最佳组合)sock是MySQL(和PHP搭配之最佳组合)监听的Sock文件位置对于使用RPM安装的用户应该是/var/lib/MySQL(和PHP搭配之最佳组合)/MySQL(和PHP搭配之最佳组合)sock对于使用源码安装则是/tmp/MySQL(和PHP搭配之最佳组合)sock可以根据自己的实际情况进行变更而pathtochk则是myisamchk所在的位置DATA_DIR是你的MySQL(和PHP搭配之最佳组合)数据库存放的位置

需要注意的时如果你打算把这条命令放在你的rclocal里面必须确认在执行这条指令时MySQL(和PHP搭配之最佳组合)服务器必须没有启动!

检测修复所有数据库(表)

MySQL(和PHP搭配之最佳组合)check A o r p

以上的相关内容就是对修复损坏的MySQL数据表的介绍望你能有所收获

               

上一篇:MYSQL的master/slave数据同步配置

下一篇:利用Crontab为Linux定时备份Mysql数据库