当前位置 > 首页 > Sql

检查修复mysql数据库

2011-10-19 18:15:00来源:Sql

检查优化并修复所有的数据库用:

# mysqlcheck -A -o -r -p
Enter password:
database1 OK
database2 OK
----------
修复指定的数据库用
# mysqlcheck -A -o -r Database_NAME -p
即可
另外如果只是对某个表进行修复可以用:myisamchk或isamchk
其中myisamchk适用于MYISAM类型的数据表,而isamchk适用于ISAM类型的数据表。这两条命令的主要参数相同,一般新的系统都使用MYISAM作为缺省的数据表类型,这里以myisamchk为例子进行说明。当发现某个数据表出现问题时可以使用:
myisamchk tablename.MYI
进行检测,如果需要修复的话,可以使用:
myisamchk -of tablename.MYI
关于myisamchk的详细参数说明,可以参见它的使用帮助。需要注意的时在进行修改时必须确保MySQL服务器没有访问这个数据表,保险的情况下是最好在进行检测时把MySQL服务器Shutdown掉。
另外可以把下面的命令放在你的rc.local里面启动MySQL服务器前:
[ -x /tmp/mysql.sock ] && /pathtochk/myisamchk -of /DATA_DIR/*/*.MYI
其 中的/tmp/mysql.sock是MySQL监听的Sock文件位置,对于使用RPM安装的用户应该是 /var/lib/mysql/mysql.sock,对于使用源码安装则是/tmp/mysql.sock可以根据自己的实际情况进行变更,而 pathtochk则是myisamchk所在的位置,DATA_DIR是你的MySQL数据库存放的位置。

1,简单的修复模式
myisamchk -r -q path/数据库/坏表.MYI
注:-r ----恢复模式 -q ----快速修复

2,使用安全修复模式

myisamchk --safe-recover path/数据库/坏表.MYI

3,困难的修复模式

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

把数据文件移更安全的地方。
使用表描述文件创建新的(空)数据和索引文件:
shell> mysql db_name
mysql> Delete FROM tbl_name;
mysql> quit

将老的数据文件拷贝到新创建的数据文件之中。(不要只是将老文件移回新文件之中;你要保留一个副本以防某些东西出错。)
回到阶段2。现在myisamchk -r -q应该工作了。(这不应该是一个无限循环)。

4,非常困难的修复模式

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

从一个备份恢复描述文件并且回到阶段3。你也可以恢复索引文件并且回到阶段2。对后者,你应该用myisamchk -r启动。
如果你没有一个备份但是确切地知道表是怎样被创建的,在另一个数据库中创建表的一个拷贝。删除新的数据文件,然后从其他数据库将描述和索引文件移到破坏的数据库中。这给了你新的描述和索引文件,但是让数据文件独自留下来了。回到阶段2并且尝试重建索引文件。

5,优化表结构
myisamchk -r 表
也可以使用sql语句来优化OPTIMIZE TABLE


来自:http://doc.linuxpk.com/67030.html


  • 百度“被”黑与Google“被”关

    2010-1-13 15:54:00

    今天看到一则很出人预料的消息,说是 Google 谷歌在其官方博客上宣布,考虑关闭中国运营及网站 Google .cn,一时间搞不清楚南北,于是找到了那篇文章,让同事中自称英语六级的翻译了一下,当然

  • SQL Server datetime数据类型设计、优化误区

    2011-1-22 17:45:00

    前些时间一直在关注数据库的优化问题 在 SQL Server 2005 中,有一个表 TestDatetime ,其中 Dates 这个字段的数据类型是 datetime ,显示的是 ‘20

  • 新闻集团已经开始屏蔽 Google 搜索了?

    2009-12-2 6:59:00

    尽管从新闻集团旗下众多网站的robots.txt文件里看不出任何端倪,尽管 Google 搜索引擎依然显示MySpace的索引页面依然有1亿7900万之多,但从 Google Search API

  • Google针对Gmail界面做出微调 更新功能按钮

    2009-2-4 13:20:00

    日前, 对 Gmail 的邮件列表和邮件上方的快捷标签进行了变动,似乎同样是全球统一变动,没有调用系统的按钮,而是使用自家样式,英文版 Gmail 和中文版 Gmail 同时调整了: 目前的快捷标签

  • 如何在SQL Server格式的日期

    2010-9-11 20:22:00

    格式化日期 第1步 创建日期的变量。下面的代码设置了一个日期变量,用于设置格式使用。这个变量被声明和分配当前日期和时间的 SQL 服务器。 申报日期时间@ myDate 设置@

  • SQL Server2008 R2如何查询数据库所在硬盘分区大小?

    2012-7-9 16:52:00

    求各位大侠帮忙研究一下,小弟想做一个数据库占比:就是拿当前数据的大小/当前安装数据库的硬盘分区大小=占比 当前数据大小,小弟已经找到方法:exec sp_spaceused 但是不会查数据库

  • SQL Server的分页查找

    2010-9-23 7:41:00

    我在这里举一个数据库分页查询的实例,相信读者能很容易的明白其中的逻辑 ? 1.首先在数据库中创建一张表,如图,命名为Table_1 ? 2.输入如下随机数据,如图所示的10条记录

  • sqlserver怎么把小数点后面多余的0去掉?

    2010-11-8 13:04:00

    sqlserver怎么把小数点后面多余的0去掉? select 3000/10000.0 --想变成0.3 select 3300/10000.0 --想变成0.33 se

  • SQL中时间与C#时间比较" href="http://blog.knowsky.com/249895.htm" target="_blank">SQL中时间与C#时间比较

    2011-7-3 21:10:00

    通过上以步骤将C#和数据库时间都转化为“07-03-2011” 格式,就可以比较了

  • mysql存储过程学习笔记--php应用

    2011-8-27 4:39:00

    点烟看寂寞燃烧 孤单了,点支香烟,静静的看着它在指尖燃烧殆尽. 烟之点燃,是为了燃烧一切的寂寞. 连接数据库 <?php $mysqli = new mysqli("lo