【MySQL数据库 | 第十九篇】SQL性能分析工具

00116ab36e3041f684accae18a95e827.png

目录

 

前言:

SQL执行频率:

慢查询日志:

profile:

profile各个指令:

总结:


前言:

        本篇我们将为大家讲解SQL性能的分析工具,而只有熟练的掌握了性能分析的工具,才可以更好的对SQL语句进行优化。虽然我们在自己练习的时候对这种优化感知并不明显,但是如果我们要处理几千几万条数据,那么这种优化带来的感知就会很强,因此我们要学好SQL语句的性能分析的工具,熟练掌握SQL的优化,才可以更加有把握解决现实生活中的实际问题

SQL执行频率:

        SQL执行频率是指在一定时间范围内某个SQL语句在数据库中被执行的次数。SQL执行频率的高低可以反映出该语句在实际业务中的重要性和影响力。

        对于一个复杂的应用系统,其数据库中可能存在大量的SQL语句,有些语句在实际使用中频率较高,有些则可能很少使用或者仅用于特定情况。对于频率较高的SQL语句,如果它们的执行效率低下,可能会导致数据库性能下降,影响整个系统的运行效率。

        因此,在进行SQL优化时,从SQL执行频率的角度出发,通常会优先考虑优化那些执行频率较高的查询语句。这些查询语句可能涉及到的数据表和字段也是比较重要的,需要认真进行索引设计和数据库结构优化。

        同时,SQL执行频率也可以作为数据库性能监控的一个指标。通过对SQL执行频率的监控、统计和分析,可以及时发现系统中执行频率较高的SQL语句,定位并解决数据库性能问题。

查询方法:
        MySQL客户端连接成功之后,通过 show [session | global] status 命令可以提供服务器状态信息,通过如下指令就可以当前数据库中 INSERT , UPDATE ,  DELETE , SELECT 的访问频次:

SHOW GLOBAL STATUS LIKE 'COM_______';

补充概念:服务器状态信息

        MySQL服务器状态信息是指数据库服务器当前的状态信息,包括各种性能指标、资源使用情况、连接信息、缓存和锁状态等。通过查看这些状态信息,可以了解数据库服务器的工作状态、瓶颈问题和性能瓶颈等,帮助我们进行系统优化和调整。

我们在 DataGrip 中进行查询:
05a90d11fe584212a9f5043687fc97d3.png

 这些查询结果分别为:

  • Com_binlog:   执行 BINLOG 操作的次数,即写二进制日志的次数;
  • Com_commit: 执行 COMMIT 操作的次数,即提交事务的次数;
  • Com_delete:   执行 DELETE 操作的次数,即删除数据的次数;
  • Com_import:   执行 LOAD DATA 导入数据的次数;
  • Com_insert:    执行 INSERT 操作的次数,即插入数据的次数;
  • Com_repair:    执行 REPAIR TABLE 修复表的次数;
  • Com_revoke:  执行 REVOKE 操作的次数,即取消授权的次数;
  • Com_select:   执行 SELECT 操作的次数,即查询的次数;
  • Com_signal:   执行 SIGNAL 操作的次数;
  • Com_update: 执行 UPDATE 操作的次数,即更新数据的次数;
  • Com_xa_end:执行 XA END 操作的次数,即提交分布式事务的次数。

这些命令在 MySQL 中具有不同的作用和用途,通过统计执行这些命令的次数,可以更加全面地了解 MySQL 服务器的工作状态和性能瓶颈,从而进行数据库性能优化和故障排查。

 tips:

在 MySQL 中,执行一次 SELECT 查询语句会生成多个命令请求,包括 Com_select、Handler_read_key、Handler_read_first、Handler_read_next 等。这些命令请求都会被累加到相应的命令计数器中。

如果在执行一次 SELECT 查询语句后,该命令计数器的值会增加 n,这是因为生成了 n 个命令请求。因此,如果你在 DataGrip 中执行多次 show global status 命令,每次命令执行都会使 com_select 计数器的值增加 n。

通过查询指令,我们可以快速的知道目前数据库哪些类型的语句占据数据库的绝大部分,也就确定了优先优化目标。 

那我们知道了优化的主要目标是哪类语句,我们又如何找出要对这类语句中的哪些语句进行优化呢?我们可以采用慢查询日志

慢查询日志:

        慢查询日志(slow query log)是 MySQL 中的一项功能,用于记录执行时间超过特定阈值的 SQL 语句的日志。慢查询日志包括每个 SQL 语句的执行时间、扫描的行数、使用的索引、执行的方式等信息。通过分析慢查询日志,可以定位数据库的性能问题,优化查询语句或数据库结构来提升系统性能。

        MySQL 提供了配置慢查询日志的相关参数,包括慢查询阈值、慢查询日志文件名、日志格式等。

        默认情况下,MySQL 没有开启慢查询日志。(这里是基于linux的,Linux会自动关闭)需要在 MySQL 配置文件(/ect/my.cnf)中设置 slow_query_log 参数为 ON,以开启慢查询日志的记录。另外,还需要设置 long_query_time 参数为一个时间阈值,单位为秒。当 SQL 查询的执行时间超过该阈值时,MySQL 会将该查询记录到慢查询日志中。

        通过慢查询日志,可以对具体的 SQL 查询语句进行性能分析和优化。一些常见的优化手段包括:修改查询语句的语法;创建或修改索引;优化表结构等。除此之外,还可以利用慢查询日志来监控数据库系统的性能瓶颈,分析表负载、索引使用情况、数据分布等方面的信息,以进一步完善数据库的性能和可用性。

检查慢查询日志是否开启:

SHOW VARIABLES LIKE 'SLOW_QUARY_LOG';

运行结果:
902008e5e15b4c53a87479715eb48f19.png

 没有开启的需要在Datagrip中配置如下信息:

SET GLOBAL slow_query_log = 1;  # 开启慢查询日志SET GLOBAL long_query_time = 1;  # 设置慢查询阈值为 1 秒钟

设置慢查询阈值的意义是:只要待查询的语句超过了设定阈值,我们就会把他记入慢查询日志之中,供后续我们进行针对优化。
开启之后我们可以看到e4feaa4b70ee44b0931fcc8f8471869e.png

 第一个是确定慢查询表已经开启记录,第二个则是告诉我们慢查询的表名。

那么我们可以直观的在文件资源管理器中查看慢查询表:
1ea1b58ec350431cb61ef3f225bec186.png

 点击进入Data:
206b8e94a9cc4f90904ce9f855e9eac0.png

 这个就是我们的慢查询表。

需要注意的是Data基本上都会被隐藏,需要我们先对这个文件以管理员模式进行访问,如果还是不显示的话,我们就在MySQL客户端执行这条语句

 SELECT @@datadir;

点击执行后,运行结果就是Data的地址,我们直接访问就可以了

 468e04cc463e422795387e7b77324679.png

慢查询表:

770c06910c1d4a3ca469a205864effe6.png

 我们尝试执行这样一句:

select sleep (10);

执行结束后,我们查看慢查询表:
9b8d4e3fb2394482b976f8941d3a900f.png

 我们可以看到有关于这条语句的执行用户,使用的哪一个数据库,以及执行的语句都会被记录下来。

profile:

MySQL的`PROFILE`是一个可以用来分析执行查询语句的工具。它可以让我们更好地了解查询执行过程中的各种时间和资源开销,包括:

  • 1. 执行查询语句所需的时间
  • 2. 查询语句返回的行数和大小
  • 3. 系统在执行查询语句时所使用的资源,如CPU时间、磁盘和内存使用情况等

使用`PROFILE`可以帮助我们优化查询语句,发现慢查询问题,以及更好地了解MySQL数据库引擎执行查询的方式。

简单的来讲,使用profile可以告诉我们具体的每一条语句耗时多少,具体耗时在哪个环节,让我们可以做出更加具体的优化。

但是在使用之前,我们还要查询当前的MySQL是否支持profile

select @@have_profiling;

84f2c75689fe43b58151d2d8433f173f.png

 通过查询我们可以看到目前是支持profile的,而默认情况下profile是关闭的,因此我们再次执行语句,查询当前profiling是否开启:

select @@profiling;

ffbf95ce9b1e46018702af6139659bd4.png

于是我们调用下面的语句开启profiling

set profiling =1;

运行结果:
ffc9510f8c75417285d88713441a2db7.png

profile各个指令:

1.查看每一条SQL的耗时基本情况

show profiles;

2.查看指定query_id的SQL语句的各阶段耗时:

show profile for query query_id;

3.查看指定query_if的SQL语句CPU使用情况:

show profile cpu for query query_id;

我们用语句1来举一个例子:

我们执行语句:

select name from emp where id =1;show profiles ;

cc5430e786b94f65910a90929f9a3513.png 这段SQL语句的作用大致如下:

1. 第一行查询上一个查询语句的执行结果中是否包含警告信息。
2. 第二行查询当前所在的数据库名称。
3. 第三行和第四行都是执行`SHOW WARNINGS`,查询语句是否产生了警告信息。
4. 第五行和第六行分别设置`net_write_timeout`和`SQL_SELECT_LIMIT`的值。
5. 第七行查询`emp`表中`id`为1的员工的姓名。
6. 第八行和第九行查询当前会话的事务隔离级别。
7. 第十一行将当前会话的事务隔离级别设置为读写模式。
8. 第十三行查询当前会话的事务隔离级别是否被设置为只读模式。
9. 第十四行和第十五行执行`SHOW WARNINGS`语句查询语句是否产生了警告信息。
10. 第十六行和第十七行都是重新设置`net_write_timeout`和`SQL_SELECT_LIMIT`的默认值。

总之,`SHOW WARNINGS`语句可以用来查看最后一次执行的查询语句是否产生了警告信息,警告信息可以包括查询语句执行过程中产生的一些异常和错误信息。

总结:

        本篇我们讲解如何利用 SQL执行频率,查询慢日志,profile来确定需要对哪些句子进行优化他们分别起到了:哪一部分需要被优化,哪些语句需要被优化,如何对语句进行更具体的优化的作用,但这三个也只是从时间角度粗略的评判哪些语句需要被优化,而下一篇我们将会讲解explain,他提供了查看执行计划的功能,在实际生活中我们也经常通过它来评判语句性能,因此大家要做好准备,熟练的掌握这一篇的内容,充满信心的学习下一篇章。

如果我的内容对你有帮助,请点赞,评论,收藏。创作不易,大家的支持就是我坚持下去的动力!

34bf194e40e44751b7e31decddc018b3.png

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/630.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言学习(二十九)---内存操作函数

在上一节内容中,我们学习了有关字符串操作的函数,其中分为了限制长度和不限制长度两种方式,虽然上节内容已经在很大程度上有助于程序的实现,但是其有一个致命的缺陷,聪明的你一定已经猜到了吧,对的&#xf…

一面、二面、三面有什么区别?

很多公司面试都分一面、二面、三面甚至更多,大家可能会好奇,为什么要面这么多面,每一面又有啥区别呢? 首先我来回答下为什么要这么多面,最核心的是最后3点: 如果光是一个人面,担心会看走眼&…

Python强类型编程

Python是一门强类型的动态类型语言,具体如下特性: 可以动态构造脚本执行、修改函数、对象类型结构、变量类型但不允许类型不匹配的操作 第一个例子体现动态性:用字符串直接执行代码,动态构建了一个函数并执行,甚至给…

IDEA创建一个Servlet项目(tomcat10)

一、创建maven项目 org.apache.maven.archetypes:maven-archetype-webapp 二、增加Servlet依赖 tomcat9及以前依赖 <!--加入servlet依赖&#xff08;servlet的jar&#xff09;--><dependency><groupId>javax.servlet</groupId><artifactId>ja…

设计模式-抽象工厂模式

抽象工厂模式 1、抽象工厂模式简介2、具体实现 1、抽象工厂模式简介 抽象工厂模式(Abstract Factory Pattern)在工厂模式尚添加了一个创建不同工厂的抽象接口(抽象类或接口实现)&#xff0c;该接口可叫做超级工厂。在使用过程中&#xff0c;我们首先通过抽象接口创建不同的工厂…

NoSQL之 Redis配置与优化

文章目录 一、关系数据库与非关系型数据库关系型数据库&#xff1a;非关系型数据库关系型数据库和非关系型数据库区别&#xff1a;非关系型数据库产生背景 二、Redis简介Redis 具有以下几个优点&#xff1a;使用场景&#xff1a;哪些数据适合放入缓存中Redis为什么这么快 三、R…

4、数据库操作语句:聚合函数

目录 1、定义 2、常用的聚合函数 1&#xff09;Avg/sum&#xff1a;只适用于数值类型的字段&#xff08;或变量&#xff09;。 2&#xff09;Max/min:适用于数值类型、字符串类型、日期时间类型的字段&#xff08;或变量&#xff09; 3&#xff09;Count&#xff1a; ①作…

SpringBoot自定义starter之接口日志输出

文章目录 前言文章主体1 项目全部源码2 项目结构介绍3 starter 的使用3.1 配置文件 application,yml的内容3.2 启动类3.3 控制器类 4 测试结果 结语 前言 本文灵感来源是一道面试题。 要求做一个可以复用的接口日志输出工具&#xff0c;在使用时引入依赖&#xff0c;即可使用。…

OpenCV学习笔记 | ROI区域选择提取 | Python

摘要 ROI区域是指图像中我们感兴趣的特定区域&#xff0c;OpenCV提供了一些函数来选择和提取ROI区域&#xff0c;我们可以使用OpenCV的鼠标事件绑定函数&#xff0c;然后通过鼠标操作在图像上绘制一个矩形框&#xff0c;该矩形框即为ROI区域。本文将介绍代码的实现以及四个主要…

Vue中如何进行游戏开发与游戏引擎集成?

Vue中如何进行游戏开发与游戏引擎集成&#xff1f; Vue.js是一款流行的JavaScript框架&#xff0c;它的MVVM模式和组件化开发思想非常适合构建Web应用程序。但是&#xff0c;如果我们想要开发Web游戏&#xff0c;Vue.js并不是最合适的选择。在本文中&#xff0c;我们将介绍如何…

edge自带断网游戏

在没有网络时你会不会很无聊&#xff1f;博主告诉你一个edge浏览器自带的断网小游戏&#xff0c;让你在断网时也能玩游戏&#xff01; 网址&#xff1a; 打开edge://surf这个断网游戏网站即可游玩&#xff1a; 作弊码既隐藏模式&#xff1a; 输入microsoft&#xff08;意思就…

Axure教程——图片轮播(纵向滚动)

本文介绍的时用Axure中的动态面板制作图片轮播之纵向滚动 一、预览效果 预览地址&#xff1a;https://c1s4i1.axshare.com 二、功能描述 图片纵向自动滚动播放 三、元件制作 拖入一个动态面板&#xff0c;命名为1&#xff0c;设置大小为375*155&#xff0c;并设置四个状态&…