SQL性能分析

查看数据库操作频次

使用SHOW GLOBAL STATUS LIKE 'Com_______'; 指令,能查看当前数据库的INSERTUPDATEDELETESELECT访问频次 。若以查询为主,需重点优化查询相关性能,如索引;若以增删改为主,可考虑事务处理、批量操作等方面的优化 。

为什么我用DateGrip 查询一次表,我的Com_select增加了9次?

Com_select 增加多次是因为 DataGrip 的 可视化操作背后隐藏了多条 SELECT 语句 ,用于获取数据、元信息或实现交互功能。这是客户端工具的正常行为,并非异常。如果需要精确控制 SELECT 次数,建议通过工具设置或手动编写 SQL 来减少不必要的查询。

慢查询日志

MySQL 的慢查询日志是一种用于记录数据库中执行时间较长的 SQL 语句的日志功能,是数据库性能优化的重要工具。

作用

  • 定位性能瓶颈:通过记录执行时间超过设定阈值的 SQL 语句,帮助数据库管理员和开发人员找出那些消耗大量时间的查询,从而定位数据库性能瓶颈所在。
  • SQL 优化依据:提供了 SQL 语句的实际执行性能数据,如执行时间、锁等待时间、扫描行数等,为优化 SQL 语句提供了真实可靠的依据。可以根据这些数据来调整查询条件、添加索引或者重写 SQL 逻辑 。
  • 系统监控:长期监控慢查询日志,能观察数据库性能随时间的变化趋势,提前发现潜在的性能问题,以便及时调整系统配置或进行优化 。
  • 索引优化:可设置记录未使用索引的查询,帮助发现数据库中可能存在的索引缺失或无效索引使用情况,进而针对性地优化索引 。

工作原理

  • 启用与配置 :通过设置全局变量来开启和配置慢查询日志相关参数。
    • slow_query_log :慢查询日志总开关,默认值为 OFF(关闭 ),设置为 ON1 时启用慢查询日志 。
    • slow_query_log_file :用于指定慢查询日志文件的存储位置和名称,默认位于 MySQL 数据目录下,文件名一般为 hostname - slow.log
    • long_query_time :定义慢查询的时间阈值,默认是 10 秒,即 SQL 语句执行时间超过这个值就会被记录到慢查询日志中。从 MySQL 5.6 版本起,支持设置小于 1 秒的小数,如 0.1 秒,可根据实际需求调整 。

配置方式

  • 配置文件设置(永久生效) :在 MySQL 配置文件(如 Linux 系统下的my.cnfmy.ini )的[mysqld] 模块中添加或修改相关参数。例如:
复制代码
  slow_query_log = 1
  slow_query_log_file = /var/log/mysql/mysql-slow.log  # 可按需指定日志文件路径
  long_query_time = 1  # 慢查询阈值设为1秒,可调整
相关推荐
尽兴-4 分钟前
SQL 执行失败如何回滚?事务已提交还能恢复吗?——MySQL 误操作数据恢复全指南
sql·mysql·binlog·undolog·redolog
瀚高PG实验室18 分钟前
逻辑导入导出(pg_dump/pg_restore)用法2-导入到不同的schema或tablespace
数据库·瀚高数据库
whyfail23 分钟前
前端数据存储新选择:IndexedDB与Dexie.js技术指南
前端·javascript·数据库
煎蛋学姐26 分钟前
SSM校园快递系统q9061(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·开题报告·java 开发·校园信息化·ssm 框架
元亓亓亓36 分钟前
考研408--操作系统--day11--文件管理&逻辑物理结构&目录&存储空间管理
数据库·考研·文件管理·408
cly11 小时前
Ansible自动化(十三):调试与优化
数据库·自动化·ansible
QQ_4376643141 小时前
redis相关命令讲解及原理
数据库·redis·缓存
萤丰信息1 小时前
开启园区“生命体”时代——智慧园区系统,定义未来的办公与生活
java·大数据·运维·数据库·人工智能·生活·智慧园区
TDengine (老段)2 小时前
TDengine Rust 连接器进阶指南
大数据·数据库·物联网·rust·时序数据库·tdengine·涛思数据
二哈喇子!2 小时前
MySQL数据库操作命令【SQL语言】
数据库·sql·视图与索引