mysqladmin、mysqlshow、mysqlcheck的工具使用

 更新时间:2024年07月05日 10:28:03   作者:码农老张Zy  
我们一般使用mysql客户端工具来进行日常的数据库操作,本文主要介绍了mysqladmin、mysqlshow、mysqlcheck的工具使用,具有一定的参考价值,感兴趣的可以了解一下

在日常的使用中,我们一般使用 mysql 客户端工具来进行日常的数据库操作,但其实,整个 MySQL 系统所提供的客户端工具远不止 mysql 一个。今天,我们就来简单地了解一下另外三个工具,分别是 mysqladmin、mysqlshow、mysqlcheck 。

mysqladmin

mysqladmin 这个命令行工具其实大家应该多少会接触过一点,它的作用是用于管理操作一些服务器配置和当前的状态信息,并且可以创建数据库。比如说我们去创建一个新数据库。

[root@localhost ~]# mysqladmin create ma_test;

同时,它也可以用于查看一些服务器的状态信息,比如说我们经常会使用的 processlist ,就可以直接使用 mysqladmin 来查看。

[root@localhost ~]# mysqladmin  processlist
+----+-----------------+-----------+----+---------+-------+------------------------+------------------+
| Id | User            | Host      | db | Command | Time  | State                  | Info             |
+----+-----------------+-----------+----+---------+-------+------------------------+------------------+
| 5  | event_scheduler | localhost |    | Daemon  | 11752 | Waiting on empty queue |                  |
| 18 | root            | localhost |    | Query   | 0     | init                   | show processlist |
+----+-----------------+-----------+----+---------+-------+------------------------+------------------+

当然,还有更多的功能,比如说修改密码、查看变量信息、关闭服务、刷新表等等功能。这里就不一一进行演示了,有兴趣的小伙伴可以自己尝试一下。

mysqlshow

这个客户端工具主要是用于快速显示数据库信息,可以看到数据库是否存在表或者表的列以及索引信息。它的作用其实非常类似于在 mysql 中的 SHOW 的作用。

[root@localhost ~]# mysqlshow
+--------------------+
|     Databases      |
+--------------------+
| information_schema |
| ma_test            |
| mysql              |
| performance_schema |
| sys                |
| test               |
| test1              |
+--------------------+

直接使用这个工具,其实就是类似于 SHOW DATABASES; 的作用。在上面显示的内容中,可以看到前面我们刚刚使用 mysqladmin 创建的 ma_test 库。我们也可以指定数据库名称,这样就可以看到这个数据库下的表信息。

[root@localhost ~]# mysqlshow test
Database: test
+----------+
|  Tables  |
+----------+
| db_test  |
| raw_test |
| t        |
+----------+

接下来我们再把表名指定上,直接就可以获取到这个表中列字段的信息。

[root@localhost ~]# mysqlshow test t
Database: test  Table: t
+-------+------+-----------+------+-----+---------+-------+---------------------------------+---------+
| Field | Type | Collation | Null | Key | Default | Extra | Privileges                      | Comment |
+-------+------+-----------+------+-----+---------+-------+---------------------------------+---------+
| id    | int  |           | YES  |     |         |       | select,insert,update,references |         |
+-------+------+-----------+------+-----+---------+-------+---------------------------------+---------+

非常有意思吧,可以直接在命令行中就获取到库、表、列的信息。另外我们还可以加一些参数,看到更详细的信息。

[root@localhost ~]# mysqlshow test -v -v
Database: test
+----------+----------+------------+
|  Tables  | Columns  | Total Rows |
+----------+----------+------------+
| db_test  |        3 |          9 |
| raw_test |        3 |          0 |
| t        |        1 |          1 |
+----------+----------+------------+
3 rows in set.

-v 参数代表的是 --verbose 的简写,它的作用是显示详细的信息,这里写了两个会多出两列,分别表示列的数据和行的数量。如果只有一个 -v 的话,则只显示列的数据信息。

mysqlcheck

最后我们再来看看 mysqlcheck 这个工具,它的作用是进行表的维护,可以检查、修复、优化或者分析表。没错,也是我们可以在 mysql 客户端中进行的一些操作,在这里可以直接通过这个外部命令行工具来实现。

[root@localhost ~]# mysqlcheck --all-databases
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.replication_asynchronous_connection_failover OK
mysql.replication_asynchronous_connection_failover_managed OK
mysql.replication_group_configuration_version      OK
mysql.replication_group_member_actions             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
mysql.user                                         OK
sys.sys_config                                     OK
test.db_test                                       OK
test.raw_test                                      OK
test.t                                             OK


[root@localhost ~]# mysqlcheck test
test.db_test                                       OK
test.raw_test                                      OK
test.t                                             OK

这个命令行工具如果不指定数据库名称的话,就需要使用 --all-databases 参数,这样就会检查所有库中的所有表,如果指定了数据库名称的话,就会检查指定数据库中的表。每一个表后面的 OK 就是表示表状态正常。

仅仅检查表状态有意义吗?这个工具的作用可不仅限于此,它还可以进行  CHECK TABLE,REPAIR TABLE,ANALYZE TABLE 和 OPTIMIZE TABLE 这些操作,只需要增加相应的参数即可,比如说我们使用 OPTIMIZE 去优化表空间。

[root@localhost ~]# mysqlcheck -o test tt
test.tt                                            OK

-o 表示的就是 --optimize 的意思,其实实际就是在 mysql 客户端中我们执行针对 tt 表的 OPTIMIZE TABLE 操作。不过这几个操作更推荐在 MyISAM 上使用,效果也更好,而且更主要的是这些操作会锁表,是非不得已情况下才要使用的命令和工具,所以大家先了解一下就好了。

总结

一口气看了三个客户端工具,非常简单,但是其实在我们的日常工作中却并不是很常见。一般来说可能在一些自己写的 shell 运维工具脚本中才能见到它们的身影。除了这三个之外,其实还有一些其它的客户端工具,像是非常常用的 mysqldump ,这个工具我们在将来学习 MySQL 备份相关的内容时再进行深入的学习。

参考文档:

https://dev.mysql.com/doc/refman/8.0/en/mysqladmin.html

https://dev.mysql.com/doc/refman/8.0/en/mysqlcheck.html#option_mysqlcheck_optimize

https://dev.mysql.com/doc/refman/8.0/en/mysqlshow.html

到此这篇关于mysqladmin、mysqlshow、mysqlcheck的工具使用的文章就介绍到这了,更多相关mysqladmin mysqlshow mysqlcheck内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL select count(*)计数很慢优化方案

    MySQL select count(*)计数很慢优化方案

    这篇文章主要介绍了MySQL select count(*)计数很慢优化方案,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • 详解MySQL中存储函数创建与触发器设置

    详解MySQL中存储函数创建与触发器设置

    这篇文章主要为大家详细介绍了MySQL中存储函数的创建与触发器的设置,文中的示例代码讲解详细,具有一定的学习价值,需要的可以参考一下
    2022-08-08
  • MySQL表的基础操作大全

    MySQL表的基础操作大全

    本文系统讲解MySQL表基础操作,涵盖创建(字段定义、数据类型、存储引擎)、查看结构与数据、修改表结构(增删改字段/类型/列名)、删除表(IF EXISTS关键字)等核心内容,以实际操作语法为主,适合具备库操作基础的读者学习,感兴趣的朋友一起看看吧
    2025-08-08
  • 彻底搞懂数据库操作truncate delete drop关键词的区别

    彻底搞懂数据库操作truncate delete drop关键词的区别

    这篇文章主要为大家介绍了数据库操作truncate delete drop关键词的区别,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • mysql 误删除ibdata1之后的恢复方法

    mysql 误删除ibdata1之后的恢复方法

    如果误删除了在线服务器中mysql innodb相关的数据文件ibdata1以及日志文件 ib_logfile*,应该怎样恢复呢
    2013-12-12
  • windows下mysql忘记root密码的解决方法

    windows下mysql忘记root密码的解决方法

    windows下mysql忘记root密码的解决方法,碰到这个问题的朋友可以参考下。
    2010-02-02
  • MySQ索引操作命令总结(创建、重建、查询和删除索引命令详解)

    MySQ索引操作命令总结(创建、重建、查询和删除索引命令详解)

    本篇文章主要是对MySQL索引操作方法做了一下总结,包括创建索引、重建索引、查询索引、删除索引的操作
    2014-04-04
  • mysql查询锁表的实现方法

    mysql查询锁表的实现方法

    本文主要介绍了mysql查询锁表的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-09-09
  • MySQL BETWEEN AND踩坑记录

    MySQL BETWEEN AND踩坑记录

    这篇文章主要介绍了MySQL BETWEEN AND踩坑记录,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • 解决xmapp启动mysql出现Error: MySQL shutdown unexpectedly.问题

    解决xmapp启动mysql出现Error: MySQL shutdown unexpec

    这篇文章主要介绍了解决xmapp启动mysql出现Error: MySQL shutdown unexpectedly.问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06

最新评论