断电或非正常关机可能导致MySQL数据库出现表损坏,特别是MyISAM表数据很大的时候。有三种方法,一种方法使用MySQL的repair table的sql语句,另一种方法是使用MySQL提供的myisamchk,,最后一种是mysqlcheck命令行工具。

1.repair table(建议方法,对MyISAM引擎表有用)

(1)check table tabTest;

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

(2)repair table tabTest;

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

2. myisamchk(该工具必须运行在服务终止条件下,对MyISAM引擎表有用)。

(1)myisamchk tablename.MYI

进行检测。

(2)myisamchk -of tablename.MYI

网上说的其它方法:

那么修复test表的方法为

myisamchk -r -q /var/lib/mysql/db/test.MYI

如果修复全部表,用这个命令

myisamchk -r -q /var/lib/mysql/db/*.MYI

3.运行mysqlcheck命令行工具(该工具可以在服务运行状态下执行)

检查特定的表:

如果应用中提示某个表坏了,使用下面的命令来检查。

$ mysqlcheck -c newmandela order -uroot -p

Enter password:

newmandela.order                                   OK

newmandela 是库名, order是表名,还需要输入用户名和密码

检查一个库中的所有表:

$ mysqlcheck -c newmandela -uroot -p

Enter password:

newmandela.account                                 OK

newmandela.alarm                                   OK

newmandela.alarm_settings                          OK

newmandela.auth_group                              OK

newmandela.auth_group_permissions                  OK

newmandela.auth_permission                         OK

检查所有库中的所有表:

全部的库和表都检查一遍了。

$mysqlcheck -c --all-databases -uroot -p

Enter password:

apmonitor.acinfo                                   OK

apmonitor.apdailysts                               OK

apmonitor.apinfo                                   OK

apmonitor.apmonthsts                               OK

apmonitor.apscanlog                                OK

apmonitor.auth_group                               OK

如果只想检查某几个库呢? 可以使用 –databases 参数:

$ mysqlcheck -c --databases newmandela radius -uroot -p

Enter password:

newmandela.account                                 OK

newmandela.alarm                                   OK

newmandela.alarm_settings                          OK

newmandela.auth_group                              OK

使用 mysqlcheck 分析表:

$ mysqlcheck -a radius payment_transactionrecord  -uroot -p

Enter password:

radius.payment_transactionrecord                   Table is already up to date

上面的命令 用来分析 radius 库的 payment_transactionrecord表, -a 表示 analyze

使用 mysqlcheck 优化表:

# mysqlcheck -o radius payment_transactionrecord  -uroot -p

Enter password:

radius.payment_transactionrecord                   OK

-o 代表 optimize ,这里是优化 radius 库的 payment_transactionrecord 表

使用 mysqlcheck 修复表:

# mysqlcheck -r radius payment_transactionrecord  -uroot -p

Enter password:

radius.payment_transactionrecord                   OK

-r 代表 repair ,这里是 修复 radius 库的 payment_transactionrecord 表

检查,优化,修复表组合命令:

# mysqlcheck -uroot -p --auto-repair -c -o newmandela

Error:  mysqlcheck doesn't support multiple contradicting commands.

上面的命令报错了,去掉 -c

# mysqlcheck -uroot -p --auto-repair -o newmandela

Enter password:

newmandela.account

note     : Table does not support optimize, doing recreate + analyze instead

status   : OK

newmandela.alarm

note     : Table does not support optimize, doing recreate + analyze instead

status   : OK

newmandela.alarm_settings

note     : Table does not support optimize, doing recreate + analyze instead

status   : OK

每张表都出现了 Table does not support optimize, doing recreate + analyze instead, 代表什么意思呢? 它的意思不是说 innodb 引擎不支持 优化,可以参考 http://stackoverflow.com/questions/30635603/what-does-table-does-not-support-optimize-doing-recreate-analyze-instead-me 的回答。

mysqlcheck 常用选项

A, –all-databases 表示所有库

-a, –analyze 分析表

-o, –optimize 优化表

-r, –repair 修复表错误

-c, –check 检查表是否出错

–auto-repair 自动修复损坏的表

-B, –databases 选择多个库

-1, –all-in-1 Use one query per database with tables listed in a comma separated way

-C, –check-only-changed 检查表最后一次检查之后的变动

-g, –check-upgrade Check for version dependent changes in the tables

-F, –fast Check tables that are not closed properly

–fix-db-names Fix DB names

–fix-table-names Fix table names

-f, –force Continue even when there is an error

-e, –extended Perform extended check on a table. This will take a long time to execute.

-m, –medium-check Faster than extended check option, but does most checks

-q, –quick Faster than medium check option

mysql 修复_mysql修复表的三个方法相关推荐

  1. linux新增mysql用户_MySQL创建用户的三种方法

    前言:MySQL创建用户的方法分成三种:INSERT USER表的方法.CREATE USER的方法.GRANT的方法. 一.账号名称的构成方式 账号的组成方式:用户名+主机(所以可以出现重复的用户名 ...

  2. ABAP中创建动态内表的三种方法(转载)

    BAP中创建动态内表的三种方法 第一种: 如果我们需要的动态内表字段或者动态工作区和数据字典中的类型一致,可以直接使用CREATE DATA生成,当然也可以是自定义类型. 比如要产生和数据表MARA结 ...

  3. MySQL删除或清空表内数据的方法

    MySQL删除或清空表内数据的方法 一.使用MySQL清空表数据命令:truncate SQL语法为: truncate table 表名 注意: truncate该命令会直接将数据表内数据清空: t ...

  4. MySQL删除或清空表中数据的方法

    原标题:MySQL删除或清空表中数据的方法 要想把MySQL中的数据删除或清空,可以通过两种方法来实现:DELETE语句和TRUNCATE TABLE语句. DELETE语句可以将表中所有记录都删除, ...

  5. mysql 清空数据库所有表最简单的方法

    mysql 清空数据库所有表最简单的方法 drop database if exists dadabase_name; create database dadabase_name;

  6. php mysql修复_MySQL数据表损坏的巧妙修复

    此文章主要向大家描述的是正确修复损坏的MySQL数据表的实际操作流程,我们大家都知道断电或者非正常关机往往会导致MySQL(和PHP搭配之最佳组合)数据库出现错误.其主要有两种方法: 一种方法使用My ...

  7. mysql表删除回滚_MySQL删除表的三种方式(小结)

    drop table drop 是直接删除表信息,速度最快,但是无法找回数据 例如删除 user 表: drop table user; truncate (table) truncate 是删除表数 ...

  8. mysql锁表_MYSQL锁表问题的解决方法

    本文实例讲述了MYSQL锁表问题的解决方法.分享给大家供大家参考,具体如下: 很多时候!一不小心就锁表!这里讲解决锁表终极方法! 案例一 mysql>show processlist; 参看sq ...

  9. C mysql添加_MYSQL将表 B C 插入表A方法

    具体情形是:有三张表a.b.c,现在需要从表b和表c中分别查几个字段的值插入到表a中对应的字段.对于这种情况,我们可以使用如下的语句来实现: 1.INSERT INTO db1_name(field1 ...

最新文章

  1. Linux Shell 截取字符串
  2. VTK:绘制BorderPixelSize边框像素大小用法实战
  3. Windows消息机制详解
  4. Android 自动向上滚动,android – Recyclerview在插入数据时自动向上滚动
  5. input输入框小写字母自动转换成大写字母
  6. Socket和ServerSocket
  7. laravel修改.env不生效原因以及解决办法
  8. 转载-聊一聊深度学习的activation function
  9. 弹簧触摸开关原理图_电梯弹簧抱闸调整
  10. div添加一个点击事件(绑定点击事件)
  11. HDU 2639 Bone Collector II (dp)
  12. linux下网络配置 命令
  13. DaRT启动光盘使用详解
  14. HP Compaq 6080 Pro 主机设置wakeonlan
  15. GB2312和UTF-8
  16. C# winfrom 在button按钮上显示箭头
  17. java中关于json传图片的方法
  18. BatteryProperty上报流程
  19. firewall ip白名单设置
  20. 直流放大器2级电路设计

热门文章

  1. 连接远程ms sql server 2000企业版时出现错误:10061的解决方法
  2. [Shell 脚本] 备份数据库文件至OSS服务(纯shell脚本无sdk)
  3. 单例模式及getInstance()的用法
  4. kaliLinux下保持匿名
  5. U-Mail邮件网关测试勒索病毒样例图
  6. C++11 类型推导decltype
  7. 修改新版am335x支持1G主频的方法[来自A Xian调试记录]
  8. Input.GetAxis
  9. 启动ipython_ipython,_ipython 启动错误,ipython - phpStudy
  10. BufferedInputStream的read方法原理