linux mysql清除数据库所有表_MySQL修复指定数据库下的所有表

efd6a470a3b74a2eb87adea8f09cb9fc.png

mysql,mariadb,percona

这几天数据库频繁crash,查看日志发现类似如下的错误:

[ERROR] mysqld: Table './database/pre_forum_forumfield' is marked as crashed and should be repaired

1

[ERROR]mysqld:Table'./database/pre_forum_forumfield'ismarkedascrashedandshouldberepaired

于是乎自己查看了下,出问题的表还真不少,至少有二十几个,而且分散在不同数据库中。对于MyISAM存储引擎和ARCHIVE存储引擎来说,可以通过REPAIR TABLE来轻松的修复该表,如果觉得麻烦,phpmyadmin也提供了一键功能,选中指定的表选择repair即可。但我这有如此多的表就不能一次性全部解决吗?当然,办法是有的。

mysqlcheck -uroot -p --auto-repair -o database

1

mysqlcheck-uroot-p--auto-repair-odatabase

其中u为用户名,p为密码,此处为空表示执行命令后输入,o指定数据库名称,这条命令可以一次性搞定database库下的所有需要repair的表。也就是说当你的MySQL修复指定数据库下的所有表时,可以用上面的方法

mysqlcheck -A -uroot -p --auto-repair

1

mysqlcheck-A-uroot-p--auto-repair

与上面的命令类似,唯一的区别是A,表示所有数据库中的所有的表,当你的MySQL需要修所有数据库下的表的时候,这个更方便。

mysqlcheck -uroot -p --repair -o database

mysqlcheck -A -uroot -p --repair

1

2

mysqlcheck-uroot-p--repair-odatabase

mysqlcheck-A-uroot-p--repair

上面这两天记录经过本人测试月可以解决我的问题,唯一的区别在于–repair和–auto-repair的区别,查看了帮助之后并没发现什么本质上的区别本人也就没在深究,如果以后有明确发现在补充吧。

–auto-repair

1

–auto-repair

如果某个被检查的表破坏了,自动修复它。检查完所有表后自动进行所有需要的修复

–repair,-r

1

–repair,-r

执行可以修复大部分问题的修复,只是唯一值不唯一时不能修复。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值