如何检查和修复 MySQL 数据库和表

发布于 2022-06-03 08:56

 ● Linux公社     

当您的网站因数据库错误而损坏或无法访问时,您可能需要检查或修复 MySQL 中的数据库或表。在这种情况下,您可以使用 mysqlcheck 工具检查并修复损坏的表或数据库。mysqlcheck 是一个维护工具,允许您通过命令行界面检查、修复、分析和优化 MySQL 表。使用 mysqlcheck 的最佳功能之一是您可以在实时网站上执行数据库维护,而无需停止 MySQL 服务。

在这篇文章中,我们将解释如何检查/修复 MySQL 数据库和表。

先决条件

  • 运行 Linux 的服务器

  • 在您的服务器上配置的 root 密码

mysqlcheck的基本语法

mysqlcheck 命令行工具的基本语法如下所示:

mysqlcheck [OPTION] DATABASENAME TABLENAME -u root -p

下面显示了可以与 mysqlcheck 一起使用的每个选项的简要说明:

  • -c - 检查表是否有错误

  • -C - 检查上周之后更改的表。

  • -a - 分析表。

  • -A - 检查所有数据库。

  • -g - 检查表以获取与版本相关的更改。

  • -B , –databases – 指定多个数据库。

  • -F - 检查未正确关闭的表。

  • –fix-db-names – 修复数据库名称。

  • –fix-table-names – 修复表名。

  • -e - 执行扩展检查。

  • -r - 修复损坏的表。

在 MySQL 中检查表

有时,您可能需要检查特定数据库中的特定表。在这种情况下,您可以使用以下语法:

mysqlcheck -c db-name table-name -u root -p

例如,要检查 class 数据库中的 students 表,请运行以下命令:

mysqlcheck -c class students -u root -p

您将获得以下输出:

class.students                                      OK

检查 MySQL 中的所有表

如果要检查特定数据库中的所有表,请使用以下语法:

mysqlcheck -c db-name -u root -p

例如,要检查 class 数据库中的所有表,请运行以下命令:

mysqlcheck -c class -u root -p

您应该得到以下输出:

Enter password: class.teacher                                   OKclass.students                                      OKclass.peon                                       OK

检查和优化所有表和所有 MySQL 数据库

您可以使用以下命令检查所有表和所有数据库:

mysqlcheck -c  -u root -p --all-databases

输出:

Enter password: class.teacher                                   OKclass.students                                      OKclass.peon                                       OKguest.MyGuests                                     OKmovies.hotstar                                     OKmysql.columns_priv                                 OKmysql.component                                    OKmysql.db                                           OKmysql.default_roles                                OKmysql.engine_cost                                  OKmysql.func                                         OKmysql.general_log                                  OKmysql.global_grants                                OKmysql.gtid_executed                                OKmysql.help_category                                OKmysql.help_keyword                                 OKmysql.help_relation                                OKmysql.help_topic                                   OKmysql.innodb_index_stats                           OKmysql.innodb_table_stats                           OKmysql.password_history                             OKmysql.plugin                                       OKmysql.procs_priv                                   OKmysql.proxies_priv                                 OKmysql.role_edges                                   OKmysql.server_cost                                  OKmysql.servers                                      OKmysql.slave_master_info                            OKmysql.slave_relay_log_info                         OKmysql.slave_worker_info                            OK

您还可以使用以下命令优化所有表和所有数据库:

mysqlcheck -o root -p --all-databases

输出:

Enter password: class.teachernote     : Table does not support optimize, doing recreate + analyze insteadstatus   : OKclass.studentsnote     : Table does not support optimize, doing recreate + analyze insteadstatus   : OKclass.peonnote     : Table does not support optimize, doing recreate + analyze insteadstatus   : OKguest.MyGuestsnote     : Table does not support optimize, doing recreate + analyze insteadstatus   : OKmovies.hotstarnote     : Table does not support optimize, doing recreate + analyze insteadstatus   : OKmysql.columns_priv

在上面的输出中,您应该看到“ Table does not support optimize ”,这意味着 InnoDB 表不支持此选项。

修复 MySQL 数据库

要修复 class 数据库中的 teacher 表,请运行以下命令:

mysqlcheck -r class teacher -u root -p

输出:

mysqlcheck -r class teacher -u root -pEnter password: class.teacher                                   OK

要修复 class movies 数据库中的所有表,请运行以下命令:

mysqlcheck -r --databases class movies -u root -p

输出:

Enter password: class.teacher                                   OKclass.students                                      OKclass.peon                                       OKmovies.hotstar                                     OK


如果要检查和修复所有数据库中的所有表,请运行以下命令:

mysqlcheck --auto-repair --all-databases -u root -p


输出:

Enter password: class.teacher                                   OKclass.students                                      OKclass.peon                                       OKguest.MyGuests                                     OKmovies.hotstar                                     OKmysql.columns_priv                                 OKmysql.component                                    OKmysql.db                                           OKmysql.default_roles                                OKmysql.engine_cost                                  OKmysql.func                                         OKmysql.general_log                                  OKmysql.global_grants                                OKmysql.gtid_executed                                OKmysql.help_category                                OKmysql.help_keyword                                 OKmysql.help_relation                                OKmysql.help_topic                                   OKmysql.innodb_index_stats                           OKmysql.innodb_table_stats                           OKmysql.password_history                             OKmysql.plugin                                       OKmysql.procs_priv                                   OKmysql.proxies_priv                                 OKmysql.role_edges                                   OKmysql.server_cost                                  OKmysql.servers                                      OKmysql.slave_master_info                            OKmysql.slave_relay_log_info                         OKmysql.slave_worker_info                            OKmysql.slow_log                                     OKmysql.tables_priv                                  OKmysql.time_zone                                    OKmysql.time_zone_leap_second                        OKmysql.time_zone_name                               OKmysql.time_zone_transition                         OKmysql.time_zone_transition_type                    OK


注意:默认情况下,InnoDB 存储引擎不支持修复。在这种情况下,您需要将 MySQL 存储引擎从 InnoDB 更改为 MyISAM。

结论

在这篇文章中,我们解释了如何使用 mysqlcheck 命令行工具检查和修复 MySQL 中的表。

来自:Linux迷
链接:https://www.linuxmi.com/check-and-repair-mysql-databases-and-tables.html

我们

或下面 Linux公社



Linux公社,添加“

每天 获取 技术干货,让我们一起成长

合作联系: root@linuxidc.net

本文来自网络或网友投稿,如有侵犯您的权益,请发邮件至:aisoutu@outlook.com 我们将第一时间删除。

相关素材