[MySQL 如何分析性能]

这篇具有很好参考价值的文章主要介绍了[MySQL 如何分析性能]。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

[MySql 如何分析性能]

Sql性能分析

sql语句: 
    "show global status like "Com_______";"
结果:
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | Com_binlog    | 0     |
    | Com_commit    | 7     |
    | Com_delete    | 2     |
    | Com_insert    | 10    |
    | Com_repair    | 0     |
    | Com_revoke    | 0     |
    | Com_select    | 1400  |
    | Com_signal    | 0     |
    | Com_update    | 2     |
    | Com_xa_end    | 0     |
    +---------------+-------+

即: 当前数据库查询了1400次数,插入了1条数据,删除了2条,更新了条;
	针对数据库优化 我们只需要关注查询次数即可,因为我们操作最多的也就是查询;
    
  • 慢查询日志

    慢查询日志记录了所有执行时间超过指定参数(long_query_time,单位:秒,默认10秒)的所有SQL语句的日志。

    MySQL的慢查询日志默认没有开启,需要在MySQL的配置文件(/etc/my,cnf)中配置如下信息:

    SQL语句: show variables like 'slow_query_log';
    
    结果:
    	+----------------+-------+
        | Variable_name  | Value |
        +----------------+-------+
        | slow_query_log | OFF   |
        +----------------+-------+
        1 row in set (0.00 sec)
        
    # 我们可以看到日志默认为 关闭状态! 如需开启 修改配置文件(/etc/my,cnf)
    
    修改配置文件
    #开启MySQL慢日志查询开关
    show_query_log=1
    
    #设置慢日志的时间为2秒,SQL语句执行超过2s即为慢查询,然后就会记录慢查询日志
    long_query_time=2
    
    "“”
    配置文件中加入如上参数即可!
    "“”
    注意!!!
    # 修改完配置文件需要重启MySQL服务!
    
  • profile详情

    • show profiles 能够在做SQL优化时帮助我们了解时间都耗费到哪个地方。通过have_profiling参数,能够看到当前MySQL是否支持profile操作
    执行SQL语句查看是否支持profiling
        select @@have_profiling;
    
        # 结果:
            +------------------+
            | @@have_profiling |
            +------------------+
            | YES              |
            +------------------+
        
    # 可以看到我们当前数据库是支持profile操作的
    
    • 默认profiling是关闭的,可以通过set语句在session/global级别开启profiling:
      (session/global 代表 当前会话/全局)
    # 1。查看是否开启profiling
        select @@profiling;
        
    	结果:
            +-------------+
            | @@profiling |
            +-------------+
            |           0 |
            +-------------+
    
    # 2.开启profiling
        set profiling=1;
    
    执行一系列的业务SQL的操作,然后我们可以通过如下指令查看SQL的执行耗时
    # 查看每一条SQL的耗时基本情况
    	show profiles;
    	
    # 查看指定query_id的SQL语句各个阶段的耗时情况
    	show profile for query query_id;
    	
    # 查看指定query_id的SQL语句CPU的使用情况
    	show profile cpu for query query_id;
    
    注意:
    	query_id 为日志中记录的id号 可通过第一条指令看到!
    	
    
  • explain执行计划

    explain 或者 desc命令获取MySQL如何执行select语句的信息,包括在select语句执行过程中表如何连接和连接的顺序。

    语法:文章来源地址https://www.toymoban.com/news/detail-449161.html

    # 直接在select语句之前加上关键字explain/desc
    
    	explain select 字段列表 from 表名 where 条件;
    	
    # 例如:explain select name from t1 where id=1;
    # 结果:
    +----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------------+
    | id | select_type | table | partitions | type | possible_keys | key  | key_len | ref  | rows | filtered | Extra       |
    +----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------------+
    |  1 | SIMPLE      | t1    | NULL       | ALL  | NULL          | NULL | NULL    | NULL |    3 |    33.33 | Using where |
    +----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------------+
    
    # explain 执行计划中各字段的含义
    1、id
    	select查询的序列号,表示查询中执行select的子句或者是操作表的顺序(id相同,执行顺序从上到下;id不同。值越大越先执行!)。
    
    2、select_type
    	表示select的类型,常见的取值有:
    	simple(简单表,即不使用表连接或者子查询)、
    	primary (主查询,即外层的查询)、
    	union (union中的第二个或者后面的查询语句)、
    	subquery (select/where之后包含子查询)等
    
    3、type
    	表示连接类型,性能由好到差的连接类型为NULL、system、const、eq_ref、ref、range、index、all。
    	
    4、possible_key
    	显示可能应用在这张表上的索引、一个或者多个。
    	
    5、key
    	实际使用的索引,如果为NULL、则没有使用索引。
    
    6、key_len
    	表示索引中使用的字节数,该值为索引字段最大可能长度,并非实际使用长度、在不损失精确性的前提下、长度越短越好。
    	
    8、rows
    	mysql认为必须要执行查询的行数,在innodb引擎的表中,是一个估计值,可能是并不总是准确的。
    	
    9、filtered
    	表示返回结果的行数占需要读取行数的百分比,filtered的值越大越好。
    
    10、extra
    	代表前边字段中的值没有展示出来的信息会在这个地方展示!
    	
    # 重点关注:type、possible_key、key、key_len
    # 参考字段:rows、extra
        
    

到了这里,关于[MySQL 如何分析性能]的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL性能分析工具的使用

    当我们遇到数据库调优问题的时候,该如何思考呢?这里把思考的流程整理成下面这张图。 整个流程划分成了 观察( Show status ) 和 行动( Action ) 两个部分。字母 S 的部分代表观察(会使用相应的分析工具),字母 A 代表的部分是行动(对应分析可以采取的行动)。    

    2024年02月09日
    浏览(43)
  • MySQL高级篇——性能分析工具

     导航:   【黑马Java笔记+踩坑汇总】JavaSE+JavaWeb+SSM+SpringBoot+瑞吉外卖+SpringCloud+黑马旅游+谷粒商城+学成在线+设计模式+牛客面试题 目录 1. 数据库服务器的优化步骤 2. 查看系统性能参数 2.1 SHOW STATUS LIKE \\\'参数\\\' 2.2 查看SQL的查询成本 3. 定位执行慢的 SQL:慢查询日志 3.0 介绍 

    2024年02月02日
    浏览(32)
  • MySQL 优化—— SQL 性能分析

    MySQL 客户端连接成功后,通过 show [session | global] status 命令可以提供服务其状态信息。通过下面指令,可以查看当前数据库 CRUD 的访问频次: SHOW GLOBAL STATUS LIKE \\\'Com_______\\\'; 七个下划线代表这个七个占位。 查询数据库中整体的 CURD 频次,一般针对 select 比较多的数据库。 慢查询

    2024年02月13日
    浏览(46)
  • Mysql的SQL性能分析【借助EXPLAIN分析】

    要说sql有问题,需要拿出证据,因此需要性能分析 Mysql中有专门负责优化SELECT语句的优化器模块,主要功能:通过计算分析系统中收集到的统计信息,为客户端请求的Query提供他认为最优的执行计划(它认为最优的数据检索方式,不见得是DBA认为是最优的,这部分最耗费时间,

    2024年02月12日
    浏览(52)
  • Mysql高级2-SQL性能分析

    MySQL客户端 连接成功后,通过show [session | global] status 命令可以提供服务器状态信息,通过如下指令,可以查看当前数据库的insert,update,dalete,select的访问频次 说明1:上面的数据库被执行查询4次   慢查询日志记录了所有执行时间超过指定参数(long_query_time 单位:秒,默认

    2024年02月15日
    浏览(38)
  • [MySQL] SQL优化之性能分析

    🌈键盘敲烂,年薪30万🌈 目录 一、索引优化 1、索引是什么: 2、索引的数据结构: 3、索引种类: 4、sql分析(回表查询) 二、定位慢查询语句 1、慢查询日志 2、profile详情 3、explain执行计划(重点) 4、查看执行频次   1、索引是什么: 通过一些约束,快速查询到相应字段

    2024年02月05日
    浏览(32)
  • MySQL实践——如何查看MySQL性能

    可以使用两种机制来管理和监控MySQL服务器的运行情况。使用服务器变量来控制其运行情况,并使用服务器状态变量读取其运行情况配置和关于功能和性能的统计信息。 服务器中有很多配置变量。有些变量只能在启动时设置(被称为启动选项,这些也可以在选项文件中设置)。

    2024年02月13日
    浏览(35)
  • 性能分析之MySQL慢查询日志分析(慢查询日志)

            MySQL的慢查询日志是MySQL提供的一种日志记录,他用来记录在MySQL中响应的时间超过阈值的语句,具体指运行时间超过long_query_time(默认是10秒)值的SQL,会被记录到慢查询日志中。         慢查询日志一般用于性能分析时开启,收集慢SQL然后通过explain进行全面

    2024年02月12日
    浏览(36)
  • mysql-sql性能分析工具

            MySQL 客户端连接成功后,通过 show [session|global] status 命令可以提供服务器状态信息。通过如下指令,可以查看当前数据库的INSERT、UPDATE、DELETE、SELECT的访问频次: -- session 是查看当前会话 ; -- global 是查询全局数据 ; SHOW GLOBAL STATUS LIKE \\\'Com_\\\'; 慢查询日志记录了所有执

    2024年02月12日
    浏览(34)
  • ⑩② 【MySQL索引】详解MySQL`索引`:结构、分类、性能分析、设计及使用规则。

    个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~ 索引 : 什么是索引(index) ? 索引(index)是帮助MySQL 高效获取数据的数据结构 (有序):在数据之外,数据库系统

    2024年02月05日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包