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

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

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

先决条件

  • 在 云平台上运行 Linux 的服务器
  • 在我们的服务器上配置的 root 密码

创建 云服务器

首先,登录到我们的 云服务器。 创建一个新服务器,选择任何具有至少 1GB RAM 的 Linux 操作系统。 通过 SSH 连接到我们的云服务器并使用页面顶部突出显示的凭据登录。

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

例如,要检查班级数据库中的学生表,请运行以下命令:

mysqlcheck -c class students -u root -p

我们将获得以下输出:

class.students                                      OK

检查 MySQL 中的所有表

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

mysqlcheck -c db-name -u root -p

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

mysqlcheck -c class -u root -p

我们应该得到以下输出:

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

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

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

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

输出:

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

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

mysqlcheck -o root -p --all-databases

输出:

Enter password: 
class.teacher
note     : Table does not support optimize, doing recreate + analyze instead
status   : OK
class.students
note     : Table does not support optimize, doing recreate + analyze instead
status   : OK
class.peon
note     : Table does not support optimize, doing recreate + analyze instead
status   : OK
guest.MyGuests
note     : Table does not support optimize, doing recreate + analyze instead
status   : OK
movies.hotstar
note     : Table does not support optimize, doing recreate + analyze instead
status   : OK
mysql.columns_priv

在上面的输出中,我们应该看到“表不支持优化”,这意味着 InnoDB 表不支持此选项。

修复/修复 MySQL 数据库

要修复班级数据库中的教师表,请运行以下命令:

mysqlcheck -r class teacher -u root -p

输出:

mysqlcheck -r class teacher -u root -p
Enter password: 
class.teacher                                   OK

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

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

输出:

Enter password: 
class.teacher                                   OK
class.students                                      OK
class.peon                                       OK
movies.hotstar                                     OK

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

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

输出:

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

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

本文记录了,如何使用 mysqlcheck 命令行工具检查和修复 MySQL 中的表。 希望这将帮助我们修复损坏的表。

© 版权声明
THE END
喜欢就支持一下吧
点赞13 分享
评论 抢沙发

请登录后发表评论