MySQL中慢查询SQL语句查找和分析

慢查询日志

默认情况下,MySQL数据库没有开启慢查询日志,如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性能影响。

  • 开启慢查询日志
mysql> SHOW VARIABLES LIKE '%slow_query_log%';
mysql> SET GLOBAL slow_query_log = 1;

在这里插入图片描述

  • 查看慢查询日志
    [root@yangjjhost03 ~]# tail -500f /var/lib/mysql/yangjjhost03-slow.log
  • 查询时间,多少秒之前的为慢查询
mysql> SHOW VARIABLES LIKE '%long_query_time%';
  • 修改时间阈值
mysql> SET long_query_time = 5;

mysqldumpslow

日志分析工具 mysqldumpslow
在这里插入图片描述

  • 常用命令
    得到返回记录集最多的10个SQL
    [root@yangjjhost03 ~]# mysqldumpslow -s r -t 10 /var/lib/mysql/yangjjhost03-slow.log
  • 得到访问次数最多的10个SQL
    [root@yangjjhost03 ~]# mysqldumpslow -s c -t 10 /var/lib/mysql/yangjjhost03-slow.log
  • 得到按照时间排序的前10条里面含有关键字的查询语句
    [root@yangjjhost03 ~]# mysqldumpslow -s t -t 10 -g “tbl_emp” /var/lib/mysql/yangjjhost03-slow.log | more

profiling

可以用来分析当前会话中语句执行的资源消耗情況。可以用于SQL的调优的测量
默认情況下,参数处于关闭状态,并保存最近15次的运行结果

mysql> SHOW VARIABLES LIKE 'profiling';
  • 开启profiling
mysql> SET profiling = 1;
  • 查看一个执行计划的总执行时间
mysql> show profiles;

在这里插入图片描述

  • 具体分析一个执行计划中,SQL语句执行过程中的资源消耗情况
    show profile cpu, block io for query n(n为Query_ID)
mysql> show profile cpu, block io for query 4;

在这里插入图片描述
converting HEAP to MyISAM 查询结果太大,内存数据写到磁盘
Creating tmp table 拷贝数据到临时表,用完再删除
Copying to tmp table on disk 内存中临时表数据写到磁盘
locked
这四项最耗时耗资源

  • 其它可选参数
    在这里插入图片描述

通用日志

不建议生产环境开启

mysql> SHOW VARIABLES LIKE'%general_log%';
  • 开启通用查询日志
mysql> SET GLOBAL  general_log = 1;
  • 不希望日志输出到文件,希望输出到表中查看
mysql> SET GLOBAL  log_output = 'TABLE';
mysql> SHOW VARIABLES LIKE'%log_output%';

在这里插入图片描述

  • 查看输出
mysql> SELECT * FROM mysql.general_log;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于优化 MySQL 查询慢的 SQL 语句,可以考虑以下几个方面: 1. 使用索引:确保表的列上有适当的索引。通过分析查询执行计划,可以确定哪些索引被使用或未使用,并根据需要添加或修改索引。 2. 优化查询语句:检查查询语句是否可以优化。避免使用不必要的连接操作,使用合适的 JOIN 类型,避免使用过多的子查询或临时表。 3. 限制结果集大小:如果查询结果集非常大,但实际只需要部分结果,可以使用 LIMIT 关键字限制返回的行数。 4. 分页查询优化:对于需要分页的查询,尽量避免使用 OFFSET 关键字,它会导致 MySQL 跳过大量的行。可以使用游标或者优化查询语句结构来提高性能。 5. 缓存查询结果:对于经常被重复执行的查询,可以考虑使用缓存技术,如 Redis 或 Memcached。将查询结果缓存在内存,可以减少对数据库的访问次数。 6. 查询字段优化:只选择需要的字段,避免不必要的数据传输和存储开销。可以使用 SELECT 指定具体字段,而不是使用 SELECT *。 7. 优化表结构:合理设计数据库表结构,避免冗余和不必要的复杂性。对于大型表,可以考虑分区、分表等技术来提高查询性能。 8. 定期优化和维护:定期分析数据库性能,并进行优化和维护操作,如重新生成索引、收集统计信息、清理无用数据等。 以上是一些常见的优化方法,根据具体情况选择适合的优化策略。可以通过 MySQL 的 EXPLAIN 关键字分析查询执行计划,找出慢查询的原因,并根据需要进行相应的优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值