欢迎来到思维库

思维库

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

时间:2025-11-04 08:20:02 出处:系统运维阅读(143)

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

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

先决条件

运行 Linux 的何检和表服务器在您的服务器上配置的 root 密码

mysqlcheck的基本语法

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

复制mysqlcheck [OPTION] DATABASENAME TABLENAME -u root -p1.

下面显示了可以与 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 -p1.

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

复制mysqlcheck -c class students -u root -p1.

您将获得以下输出:

复制class.students OK1.

检查 MySQL 中的所有表

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

复制mysqlcheck -c db-name -u root -p1.

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

复制mysqlcheck -c class -u root -p1.

您应该得到以下输出:

复制Enter password:

class.teacher OK

class.students OK

class.peon OK1.2.3.4.

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

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

复制mysqlcheck -c -u root -p --all-databases1.

输出:

复制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 OK1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.

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

复制mysqlcheck -o root -p --all-databases1.

输出:

复制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_priv1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.

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

修复 MySQL 数据库

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

复制mysqlcheck -r class teacher -u root -p1.

输出:                            

复制mysqlcheck -r class teacher -u root -p

Enter password:

class.teacher OK1.2.3.

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

复制mysqlcheck -r --databases class movies -u root -p1.

输出:

复制Enter password:

class.teacher OK

class.students OK

class.peon OK

movies.hotstar OK1.2.3.4.5.

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

复制mysqlcheck --auto-repair --all-databases -u root -p1.

输出:

复制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 OK1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.

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

结论

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

分享到:

温馨提示:以上内容和图片整理于网络,仅供参考,希望对您有帮助!如有侵权行为请联系删除!

友情链接: