MySQL数据库原理学习(九)
2.5 SQL性能分析
2.5.1 SQL执行频率
MySQL 客户端连接成功后,通过 show [session|global] status 命令可以提供服务器状态信息。通过如下指令,可以查看当前数据库的INSERT、UPDATE、DELETE、SELECT的访问频次:
-- session 是查看当前会话 ;
-- global 是查询全局数据 ;
SHOW GLOBAL STATUS LIKE 'Com_______';
Com_delete: 删除次数
Com_insert: 插入次数
Com_select: 查询次数
Com_update: 更新次数
我们可以在当前数据库再执行几次查询操作,然后再次查看执行频次,看看 Com_select 参数会不会变化。
通过上述指令,我们可以查看到当前数据库到底是以查询为主,还是以增删改为主,从而为数据库优化提供参考依据。如果是以增删改为主,我们可以考虑不对其进行索引的优化。如果是以查询为主,那么就要考虑对数据库的索引进行优化了。
那么通过查询SQL的执行频次,我们就能够知道当前数据库到底是增删改为主,还是查询为主。那假如说是以查询为主,我们又该如何定位针对于那些查询语句进行优化呢?次数我们可以借助于慢查询日志。
接下来,我们就来介绍一下MySQL中的慢查询日志。
2.5.2 慢查询日志
慢查询日志记录了所有执行时间超过指定参数(long_query_time,单位:秒,默认10秒)的所有SQL语句的日志。
MySQL的慢查询日志默认没有开启,我们可以查看一下系统变量 slow_query_log。
如果要开启慢查询日志,需要在MySQL的配置文件(/etc/my.cnf)中配置如下信息:
# 开启MySQL慢日志查询开关
slow_query_log=1
# 设置慢日志的时间为2秒,SQL语句执行时间超过2秒,就会视为慢查询,记录慢查询日志
long_query_time=2
配置完毕之后,通过以下指令重新启动MySQL服务器进行测试,查看慢日志文件中记录的信息
/var/lib/mysql/localhost-slow.log。
systemctl restart mysqld
然后,再次查看开关情况,慢查询日志就已经打开了。
测试:
A. 执行如下SQL语句 :
select * from tb_user; -- 这条SQL执行效率比较高, 执行耗时 0.00sec
select count(*) from tb_sku; -- 由于tb_sku表中, 预先存入了1000w的记录, count一次,耗时
13.35sec
B. 检查慢查询日志 :
最终我们发现,在慢查询日志中,只会记录执行时间超多我们预设时间(2s)的SQL,执行较快的SQL是不会记录的。
那这样,通过慢查询日志,就可以定位出执行效率比较低的SQL,从而有针对性的进行优化。
相关文章
- MySQL数据库之旅——借助导航猫一路前行(导航猫mysql)
- Linux操作MySQL数据库:快速、安全、高效(linux操作mysql)
- MySQL数据库命名规则:简明指南(mysql数据库命名规则)
- MySQL中新建用户的常用命令总结(mysql新建用户命令)
- MySQL:安装与启动数据库(mysql安装数据库)
- Mysql跨库连接的实现(mysql跨库join)
- MySQL修改:使用UPDATE命令(mysql修改命令)
- 使用MySQL表设计工具优化你的数据库结构(mysql表设计工具)
- MySQL: 开启分布式数据库之旅(mysql是分布式数据库)
- MySQL数据库的在线迁移指南(mysql在线迁移)
- MySQL中更新数据的正确方法(mysql中更新语句)
- MySQL数据库的复制技术.(mysql复制数据库)
- MySQL快速入门:基础视频教程(mysql入门视频教程)
- 如何在QT应用程序中使用MYSQL进行编程?(qt的mysql编程)
- MySQL联合查询指南:教您如何使用联合查询优化数据库检索(mysql数据库联合查询)
- MySQL数据库事务级别:了解ACID特性,保证数据一致性。(mysql数据库事物级别)
- 深入理解MySQL数据库编码(数据库编码mysql)
- MySQL:数据库统一无可比拟(mysql 唯一)
- 利用MySQL中的log命令行优化数据库管理(mysql中log命令行)
- MySQL中的Cross Join用法(mysql中cross)
- 使用Bash脚本简化MySQL数据库连接(bash能连接mysql)
- ASP连接MySQL,开发数据库应用变得更容易(asp可以连mysql)
- 解决MySQL不稳定的问题(mysql不好使)