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

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.lryc.cn/news/601903.html

相关文章:

  • 【测试报告】思绪网(Java+Selenium+Jmeter自动化测试)
  • 自动出题与批改系统(数学题生成+OCR识别)
  • ABB机器人多任务详解
  • OpenLayers 综合案例-轨迹回放
  • java的break能加标签,return可以加标签吗
  • 83.删除排序链表中的重复元素
  • DeepCompare文件深度对比软件“.dpcp“工程项目文件功能深度解析
  • vector使用和模拟
  • 网络虚拟化:veth,bridge,network namespace与docker网络
  • ESP32学习-FreeRTOS队列使用指南与实战
  • 使用低级上位画图法理解在对磁盘空间进行容量分配时【低级单位上位至高级单位的换算】
  • Mybatis Plus 多数据源
  • AI时代,我们更需要自己的开发方式与平台
  • Coze Studio概览(一)
  • 链表算法常用技巧与操作
  • 通过硬编码函数地址并转换为函数指针来调用函数
  • 【Agentic】通过LangGrah实现RAG评分和重写
  • 清华大学具身智能多传感器融合感知综述:背景、方法、挑战与展望
  • Flutter开发实战之CI/CD与发布流程
  • 网易大模型算法岗面经80道
  • JSON格式化与结构对比
  • 移植pbrt中的并行化到ray trace in weeks中
  • LangGraph底层API入门总结
  • OpenLayers 综合案例-地图绘制
  • 十字链表以及实现
  • SpringAI入门及浅实践,实战 Spring‎ AI 调用大模型、提示词工程、对话记忆、Adv‎isor 的使用
  • 第五章 中央处理器(CPU)知识体系与考法总结
  • 【第六节】方法与事件处理器
  • Gradle#Plugin
  • Windows---动态链接库Dynamic Link Library(.dll)