【MySQL】索引性能分析工具详解——>为sql优化(select)做准备

前言

大家好吖,欢迎来到 YY 滴MySQL系列 ,热烈欢迎! 本章主要内容面向接触过C++的老铁
主要内容含:
在这里插入图片描述

欢迎订阅 YY滴C++专栏!更多干货持续更新!以下是传送门!

  • YY的《C++》专栏
  • YY的《C++11》专栏
  • YY的《Linux》专栏
  • YY的《数据结构》专栏
  • YY的《C语言基础》专栏
  • YY的《单片机》专栏
  • YY的《STM32》专栏
  • YY的《数据库》专栏

    目录

    • 一.索引性能分析工具——>为sql优化(select)做准备
      • 1.查看SQL执行频次
        • 【1】为什么要关注执行频率
        • 【2】查看SQL执行频次语法&演示
      • 2.慢查询日志
        • 【1】慢查询日志机理机理&作用&语法
        • 【2】演示:查看慢查询日志开关是否开启
        • 【2】演示:Linux中配置慢查询日志
        • 【3】演示:实时监测慢查询日志
      • 3.profiles详情——(解决慢查询日志--自定义问题)
        • 【1】慢查询日志机理机理&作用&语法
        • 【2】演示:打开profiles开关前后对比
        • 【3】演示:执行一系列的业务SQL的操作,然后通过profile查看指令的执行耗时/各个阶段耗时/CPU使用情况:
      • 4.explain执行计划(最常用)
        • 【1】explain执行计划&语法
        • 【2】explain执行计划演示
        • 【3】explain执行计划各个字段的含义

一.索引性能分析工具——>为sql优化(select)做准备

1.查看SQL执行频次

【1】为什么要关注执行频率

  • 有张表数据量大,但是只插入不查询,所以没必要优化;
  • 通过查看增删改/查占数据库操作的比例, 来判断是否需要优化

【2】查看SQL执行频次语法&演示

MySQL客户端连接成功后,通过show [sessionlglobal] status命令可以提供服务器状态信息。通过如下指令,可以查看当前数据库的INSERT、UPDATE、DELETE、SELECT的访问频次:

SHOW GLOBAL STATUS LIKE 'Com_______‘; --模糊匹配,7个_代表7个字符

我们要关注增删查改操作

2.慢查询日志

【1】慢查询日志机理机理&作用&语法

  • 慢查询日志记录了所有执行时间超过 指定参数 (longquerytime,单位:秒, 默认10秒 )的所有SOL语句的日志——————> 要自定义参数可看下文【3.profile详情】
  • 慢查询日志的作用:一段操作后,我们可以在其中定位到效率比较低的sql,从而进行优化
  • MySQL的 慢查询日志默认没有开启 需要在MySQL的配置文件(/etc/my.cnf)中配置如下信息:
  • 配置完毕之后,通过以下指令重新启动MSQL服务器进行测试,查看慢日志文件中记录的信息/var/lib/mysql/localhost-slow.log。
    在这里插入图片描述

【2】演示:查看慢查询日志开关是否开启

show variables like 'slow query log';

在这里插入图片描述

【2】演示:Linux中配置慢查询日志

  • 登录linux,编辑mysql下的配置文件:/etc/my.cnf
    在这里插入图片描述
  • 大G跳到最后在这里插入图片描述
  • 输入在这里插入图片描述
slow_query_log=1
long_query_time=2

在这里插入图片描述

  • 重新连接后;再次查询,发现接口已开启
    在这里插入图片描述

【3】演示:实时监测慢查询日志

  • 我们开启两个窗口,第一个窗口输入如下代码查看慢查询日志实时情况
tail -f localhost-slow.1og

在这里插入图片描述

  • 第二个窗口执行一条select语句,由于用时没有超过10s,所以在第一个窗口中没有显示
    在这里插入图片描述
  • 第二个窗口执行一条典型性能低select语句,用时超过10s,所以在第一个窗口中显示

在这里插入图片描述
在这里插入图片描述

3.profiles详情——(解决慢查询日志–自定义问题)

【1】慢查询日志机理机理&作用&语法

  • 慢查询日志只记录超过10s的sql记录,想要自定义要通过profiles
  • show profiles 能够在做SQL优化时帮助我们了解时间都耗费到哪里去了
  • 通过have profiling参数,能够看到当前MySQL 是否支持 profile操作:
SELECT @@have_profiling ;
  • 默认profiling是关闭的 ,可以通过set语句在session/global级别开启profiling
  • 通过以下语句,能够看到当前profile操作 是否开启
SET profiling=1;
  • 查看profiling状态
select @profiling;
  • 执行一系列的业务SQL的操作,然后通过如下指令查看指令的执行耗时:

在这里插入图片描述

【2】演示:打开profiles开关前后对比

在这里插入图片描述

【3】演示:执行一系列的业务SQL的操作,然后通过profile查看指令的执行耗时/各个阶段耗时/CPU使用情况:

在这里插入图片描述

  • 执行一系列sql语句
    在这里插入图片描述
  • 查询profiles
    在这里插入图片描述
  • 我们想知道最后一条语句,为何花了9s多,耗费在哪些地方,我们可以接着操作
    在这里插入图片描述
    在这里插入图片描述
  • 加上cpu,可以查看指定query id的SQL语句CPU的使用情况
    在这里插入图片描述

4.explain执行计划(最常用)

【1】explain执行计划&语法

EXPLAIN 或者 DESC命令获取 MySQL如何执行 SELECT语句的信息,包括在 SELECT语句执行过程中表如何连接和连接的顺序。
在这里插入图片描述

【2】explain执行计划演示

  • 在select语句前加入explain或desc即可

在这里插入图片描述

【3】explain执行计划各个字段的含义

  • ID:select查询的序列号,表示查询中执行select子句或者是操作表的顺序(id相同,执行顺序从上到下; id不同,值越大,越先执行 )
  • select_type:表示 SELECT的类型,常见的取值有 SIMPLE(简单表,即不使用表连接或者子查询)、PRIMARY(主查询,即外层的查询)、UNION(UNION 中的第二个或者后面的查询语句)、SUBQUERY(SELECT/WHERE之后包含了子查询)等
  • type:表示连接类型,性能由好到差的连接类型为NULL、system、const、eq_ref、ref、range、index、all
  • possible_key:显示可能应用在这张表上的索引,一个或多个
  • Key:实际使用的索引,如果为NULL,则没有使用索引。
  • Key_len:表示索引中使用的字节数,该值为索引字段最大可能长度,并非实际使用长度,在不损失精确性的前提下,长度越短越好
  • rows:MySQL认为必须要执行查询的行数,在innodb引擎的表中,是一个估计值,可能并不总是准确的
  • filtered:表示返回结果的行数占需读取行数的百分比,filtered 的值越大越好。
    在这里插入图片描述

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

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

相关文章

DS18B20时序抓图

关于时序文字描述参见:DS18B20时序描述 一个完整的读数过程如下: 对应的过程如下: Reset Presence RomCmd:0xCC(Skip Rom) FunCmd:0xBE(Read Scratchpad) Data:0x01A0(Temperature,26) Reset Presence RomCmd:0xCC(Skip Rom) FunCmd:0x44(Co…

两大信号 华为又有神操作

文|琥珀食酒社 作者 | 积溪 华为的神操作又要来了 三折叠手机马上就要亮相 手机圈的所有友商们 又要睡不着觉了 这次华为选择和苹果硬刚 发布会都定在了同一天 绝对不是巧合 而是神来之笔 就是要告诉苹果 该是华为的市场 它都得拿回来 也让友商们认清了…

注册中心 Eureka Nacos

文章目录 目录 文章目录 1. 什么是注册中心? 2.常见的注册中心 3 . Eureka 4 . Nacos 5 . Nacos与Eureka的区别 总结 1. 什么是注册中心? 在最初的架构体系中, 集群的概念还不那么流行, 且机器数量也比较少, 此时直接使用DNSNginx就可以满足几乎所有服务的发现. 相…

【Qt窗口】—— 对话框

目录 (一) 对话框介绍 (二)对话框的分类 2.1 模态对话框 2.2 非模态对话框 2.3 混合属性对话框 (三)内置对话框 消息对话框 QMessageBox 颜色对话框 QColorDialog 字体对话框 QFontDialog 输入对…

Scrapy入门学习

文章目录 Scrapy一. Scrapy简介二. Scrapy的安装1. 进入项目所在目录2. 安装软件包Scrapy3. 验证是否安装成功 三. Scrapy的基础使用1. 创建项目2. 在tutorial/spiders目录下创建保存爬虫代码的项目文件3.运行爬虫4.利用css选择器Scrapy Shell提取数据例如: Scrapy 一. Scrapy…

glsl着色器学习(十)缩放

对二维图形进行缩放&#xff0c;需要用到顶点着色器&#xff0c;顶点着色器经过矩阵变换&#xff0c;会将模型空间最终转换成裁剪空间。下面就来操作矩阵 这里需要用到一个库glMatrix。 首先修改顶点着色器 <script id"vertex-shader-2d" type"x-shader/x-…

Win32创建虚拟打印机

最近有个需求需要对报告打印进行统一的管理&#xff0c;最终实现方案如下&#xff1a; 1、安装Microsoft Print To PDF虚拟打印机&#xff0c;该打印机可以将所有打印数据转换为PDF 2、通过Microsoft Print To PDF虚拟机参数复制一台新的虚拟打印机 3、创建打印输出端口&…

服务器数据恢复—LeftHand存储中raid5阵列多块磁盘离线的数据恢复案例

LeftHand存储支持RAID5、RAID6、RAID10磁盘阵列&#xff0c;同时还支持卷快照&#xff0c;卷动态扩容等。下面简单聊一下LeftHand存储的结构和一个LeftHand p4500存储中磁盘阵列数据恢复案例。 服务端&#xff1a; 客户端&#xff1a; LeftHand存储结构&#xff1a; Lefthand存…

C语言指针详解-包过系列(一)目录版

C语言指针详解-包过系列&#xff08;一&#xff09;目录版 1.内存和地址1.1内存1.2 深入理解编址 2.指针变量和地址2.1 取地址操作符&#xff08;&&#xff09;2.2 指针变量和解引用操作符&#xff08;*&#xff09;2.2.1 指针变量2.2.2 指针变量各部分理解2.2.3 解引用操作…

Oracle 常用函数大全

文章目录 一、空校验1. NVL 空校验2. COALESCE 空校验 二、排序1. ORDER BY 排序2. ORDER BY DECODE 指定值排序 三、排名1. RANK 排名2. DENSE RANK 密集排名 四、限制条数1. ROWNUM 限制2. FETCH 限制 五、字符串处理1. TO_CHAR 字符串转换2. || 字符串拼接3. CONCAT 字符串拼…

【Qt】颜色对话框QColorDialog

颜色对话框QColorDialog 颜⾊对话框的功能是允许⽤⼾选择颜⾊。继承⾃ QDialog 类。 Qt QColorDialog 的功能就是内置了调色板&#xff0c;效果和上图画图板的调色板类似。 常用方法介绍&#xff1a; QColorDialog (QWidget *parent nullptr) //创建对象的同时设置⽗对象Q…

获取navicat已保存数据库连接的密码

打开connections.ncx&#xff0c;可以看到Passwordxxx,这是加密后的密码 解密 在线的运行工具https://tool.lu/coderunner 运行如下代码&#xff0c;代码中的密码改成你的密码&#xff0c;在倒数第二行位置 <?phpnamespace FatSmallTools;class NavicatPassword{protected…

draw.io图片保存路径如何设置

当在draw.io中画图时&#xff0c;对于图片的保存经常选择了但是后面打开了又不知道图片的位置在哪&#xff0c;如下图所示&#xff0c;选择的途径很多。 为了之后存储文件较为简单&#xff0c;今天小编从源头设置图片的存储位置&#xff0c;使用浏览器设置的保存文件的路径。 …

2024年9月4日嵌入式学习

内存泄漏&#xff1a; 内存泄漏&#xff08;Memory Leak&#xff09;是指程序中已动态分配的内存由于某种原因程序未释放或无法释放&#xff0c;导致系统内存的浪费&#xff0c;严重时会导致程序运行缓慢甚至崩溃。这种情况在长时间运行的程序或大型系统中尤为常见&#xff0c;…

A02、Java编程性能调优(02)

1、Stream如何提高遍历集合效率 1.1、什么是Stream 现在很多大数据量系统中都存在分表分库的情况。例如&#xff0c;电商系统中的订单表&#xff0c;常常使用用户 ID 的 Hash 值来实现分表分库&#xff0c;这样是为了减少单个表的数据量&#xff0c;优化用户查询订单的速度。 …

2024.9.3 作业

自己实现栈和队列 代码&#xff1a; /*******************************************/ 文件名&#xff1a;sq.h /*******************************************/ #ifndef SQ_H #define SQ_H #include <iostream> #include<cstring>using namespace std; class …

Matlab R2022b使用Camera Calibrator工具箱张正友标定法进行相机标定附带标定前后对比代码

打开Camera Calibrator 在这添加你拍摄的图片 根据你每个方块的实际边长填写&#xff0c;我是15mm。 通俗一点&#xff0c;要k3就选3 Coefficients&#xff0c;否则为0&#xff1b;要p1、p2就选Tangential Distortion。然后进行计算。 可以点击右侧误差高的选中图像进行移…

【C/C++】C语言实现蛇形矩阵

目录 题目描述输入描述:输出描述:示例思路代码 题目描述 给你一个整数n&#xff0c;输出n∗n的蛇形矩阵。 输入描述: 输入一行&#xff0c;包含一个整数n 输出描述: 输出n行&#xff0c;每行包含n个正整数&#xff0c;通过空格分隔。 1<n<1000 示例 输入 4输出 …

iOS18 beta版本怎么回退至iOS17正式版本?

截止目前&#xff0c;苹果最近的iOS18的beta测试版本已经发了8版了&#xff0c;有许多朋友们都已升级提前尝鲜了&#xff0c;升级体验后许多果粉朋友们觉得有许多功能还是不够稳定&#xff0c;有些许bug&#xff0c;就想要降级&#xff0c;回退到iOS17的正式版&#xff0c;但又…

2024数博会技术成果回顾 | KPaaS助力企业数智化转型

2024年8月28日至30日&#xff0c;中国国际大数据产业博览会&#xff08;简称“数博会”&#xff09;在贵州省贵阳市隆重举行。本届数博会以“数智共生&#xff1a;开创数字经济高质量发展新未来”为主题&#xff0c;吸引了来自全球各地的400多家企业和2.1万余名嘉宾参与&#x…