当前位置: 首页 > backend >正文

MySQL进阶学习与初阶复习第四天

目录

一.mysqladmin - MySQL 服务器管理程序

作⽤

使⽤⽅法

⽀持的命令

常⽤选项

二.mysqlshow - 显⽰数据库、表和列信息

作⽤

注意事项

使⽤⽅法

常⽤选项

三.mysqldumpslow - 总结慢查询⽇志⽂件

作⽤

注意事项

使⽤⽅法

常⽤选项


一.mysqladmin - MySQL 服务器管理程序

作⽤

        mysqladmin 是⼀个执⾏管理操作的客⼾端。可以⽤来检查服务器的配置和当前状态,以及创建和删除数据库等。

使⽤⽅法

mysqladmin 可以使⽤以下语法:

mysqladmin [options] command [command-arg] [command [command-arg]] ...

⽀持的命令

        语法中的command 表⽰命令,有些命令后⾯需要跟上⼀个参数,如下列出了mysqladmin 的常⽤命令:

version

显⽰来⾃服务器的版本信息。

查看服务器状态

  • Uptime MySQL 服务器已运⾏的秒数。
  • Threads 活动线程(客⼾端)的数量。
  • Questions ⾃服务器启动以来客⼾端的问题(查询)数。
  • Slow queries 慢SQL的查询数。
  • Opens 服务器已打开的表数。
  • Flush tables 服务器已执⾏flush-*、refresh和reload命令的数量。
  • Open tables 当前打开的表数。

2. create db_name

创建⼀个数据库名为 db_name

3. drop db_name

删除名为 db_name 的数据库及其所有表。

4. extended-status

显⽰服务器状态变量的值。

5. flush-hosts

刷新主机缓存中的所有信息。

6. flush-logs [log_type ...]

刷新所有⽇志。 log_type 中可以提供以下⼀种或多种⽇志类型binary, engine, error, general, relay, slow,多个类型之间⽤空格分隔。

7. flush-privileges

重新加载授权表

8. flush-status

清除状态变量。

9. flush-tables

刷新所有表。

10. flush-threads

刷新线程缓存。

11. password new_password

设置新密码。

  • 如果密码中有空格必须⽤双引号把密码包裹起来
  • password 后可以省略新密码,mysqladmin会在之后提⽰输⼊新密码
  • password 做为最后⼀个command 时才可以省略密码值,否则下⼀个参数将作为密码被设置。

Warning 有可能存在安全问题

Setting a password using mysqladmin should be considered insecure. On some systems, your password becomes visible to system status programs such as ps that may be invoked by other users to display command lines. MySQL clients typically overwrite the command-linepassword argument with zeros during their initialization sequence. However, there is still a brief interval during which the value is visible. Also, on some systems this overwriting strategy is ineffective and the password remains visible to ps. (SystemV Unix systems and perhaps others are subject to this problem.)

12. ping

检查服务器是否可⽤

13. processlist

显⽰活动服务器线程的列表。

14. kill id , id ,...

终⽌服务器线程。如果给出了多个线程ID值,则列表中不能有空格。

15. reload

重新加载授权表。

16. refresh

刷新所有表。

17. shutdown

停⽌服务器。

18. start-replica

在副本服务器上开始复制。MySQL 8.0.26及以后的版本使⽤此命令。

19. start-slave

在副本服务器上开始复制。MySQL 8.0.26 之前使⽤此命令。

20. status

显⽰简短的服务器状态消息。

21. stop-replica

停⽌副本服务器上的复制。MySQL 8.0.26及以后的版本使⽤此命令。

22. stop-slave

停⽌副本服务器上的复制。MySQL 8.0.26 之前使⽤此命令。

23. variables

显⽰服务器系统变量及其值。

常⽤选项

        mysqladmin 的常⽤选项参考公共选项部分,可以在命令⾏中指定,也可以在选项⽂件中通过[mysqladmin] 和 [client] 组进⾏指定

二.mysqlshow - 显⽰数据库、表和列信息

作⽤

mysqlshow 客⼾端可⽤于快速查看存在哪些数据库、数据库中的表以及表中的列或索引。

注意事项

        mysqlshow 为⼀些 SHOW 语句提供了⼀个命令⾏接⼝。关于SHOW的使⽤参⻅官⽅⽂件“SHOW语句”。直接使⽤这些SQL语句也可以获得相同的信息。

使⽤⽅法

mysqlshow 可以使⽤以下语法:

mysqlshow [options] [db_name [tbl_name [col_name]]]
  • db_name tbl_name col_name 可以使⽤通配符 * ? % _
  • 如果没有指定数据库,则显⽰所有数据库名称列表。
  • 如果没有指定表,则显⽰数据库中所有匹配的表。
  • 如果没有指定列,则显⽰表中所有匹配的列和列类型。
  • 输出仅显⽰当前权限可以访问的数据库、表或列的名称。
mysqlshow test_db -uroot -p # 显⽰test_db数据库中的所有表

 mysqlshow test_db student -uroot -p # 显⽰student表中的所有字段

mysqlshow test_db student id -uroot -p # 显⽰student表中id字 段的信息

常⽤选项

        mysqlshow 的常⽤选项参考公共选项部分,可以在命令⾏中指定,也可以在选项⽂件中通过[mysqlshow] 和 [client] 组进⾏指定,具体选项参考公共选项列表。

三.mysqldumpslow - 总结慢查询⽇志⽂件

作⽤

        在平时使⽤MySQL数据库时,经常进⾏查询操作,有些查询语句执⾏的时间⾮常⻓,当执⾏时间超过设定的阈值时,我们称这个查询为慢查询,慢查询的相关信息通常需要⽤⽇志记录下来称为慢查询⽇志,mysqldumpslow可以解析慢查询⽇志⽂件并汇总其内容,有关慢查询⽇志的内容我们在MySQL服务器配置与管理专题进⾏讲解.

注意事项

        通常情况下,mysqldumpslow 会将相似的查询分组并显⽰摘要输出,⼀般会把数字和字符串⽤ N 和 "S" 代替,要想显⽰真实的值可以使⽤ -a 和 -n 选项。

使⽤⽅法

mysqldumpslow 可以使⽤以下语法

mysqldumpslow [options] [log_file ...]

如下图这样找到慢查询日志文件。

show variables like "%query%";

在没有给出任何选项的输出如下:

Reading mysql slow query log from /usr/local/mysql/data/mysqld80-slow.log
Count: 1 Time=4.32s (4s) Lock=0.00s (0s) Rows=0.0 (0), root[root]@localhostinsert into t2 select * from t1 # 执⾏的SQL
Count: 3 Time=2.53s (7s) Lock=0.00s (0s) Rows=0.0 (0), root[root]@localhostinsert into t2 select * from t1 limit N # 执⾏的SQL
Count: 3 Time=2.13s (6s) Lock=0.00s (0s) Rows=0.0 (0), root[root]@localhostinsert into t1 select * from t1 # 执⾏的SQL

常⽤选项

mysqldumpslow 的常⽤选项

选项
说明
-a
不⽤ N 'S' 代替numbers和String
-n N
在名称中包含N个以上的数字⽤ N 代替
-g pattern
仅考虑与指定模式匹配的慢查询
--help
显⽰帮助信息并退出
-h host_name
与*-slow.log⽂件名对应的MySQL服务器主机名。
可以包含通配符。默认值是*(匹配所有)。
-i name服务器示例名称
-l
不要从总时间中减去锁占⽤的时间
-r
倒序顺列
-s sort_type
如何对输出进⾏排序
-t N
显⽰输出中的前N个查询
--verbose, -v
打印有关程序功能的更多信息

-s sort_type sort_type可选的值如下所⽰:

  • t , at : 按查询时间或平均查询时间排序,默认排序
  • l , al : 按锁占⽤时间或平均锁占⽤时间排序
  • r , ar : 按发送的⾏数或平均发送的⾏数排序
  • c : 按计数排序
http://www.xdnf.cn/news/16417.html

相关文章:

  • Canvas实现微信小程序图片裁剪组件全攻略
  • 在docker中安装frp实现内网穿透
  • Ubuntu简述及部署系统
  • 负载均衡 LoadBalance
  • web刷题
  • c++11--static_assert
  • Linux->自定义shell
  • FPGA IP升级
  • 网络服务综合项目
  • Oracle 数据库报 ora-00257 错误并且执行alter system switch logfile 命令卡死的解决过程
  • XSS利用
  • 02人工智能中优雅草商业实战项目视频字幕翻译以及声音转译之以三方AI模型API制作方式预算-卓伊凡|莉莉
  • linux 板卡实现vxi11服务
  • 阿里 Qwen3 四模型齐发,字节 Coze 全面开源,GPT-5 8 月初发布!| AI Weekly 7.21-7.27
  • 初识 docker [上]
  • 《 接口日志与异常处理统一设计:AOP与全局异常捕获》
  • P图太假?AI一键融入背景!
  • vLLM 的“投机取巧”:Speculative Decoding 如何加速大语言模型推理
  • 【优选算法】BFS解决FloodFill算法
  • 零基础学习性能测试第五章:JVM性能分析与调优-GC垃圾分代回收机制与优化
  • 死锁出现的原因
  • 《计算机组成原理与汇编语言程序设计》实验报告四 Debug及指令测试
  • #影·数学计划# N1 一元一次方程讲解 未完待续
  • 基于STM32的智能康养木屋监测系统
  • vector使用和模拟
  • 在本地环境中运行 ‘dom-distiller‘ GitHub 库的完整指南
  • openshift AI 2.22安装的需求
  • 人工智能与城市:城市生活的集成智能
  • 基于 LSTM 与 SVM 融合的时间序列预测模型:理论框架与协同机制—实践算法(1)
  • Wireshark TS | 发送数据超出接收窗口