mysql慢sql分析及优化 (mysql数据库性能优化之表结构优化)

本系列为:MySQL数据库详解,为千锋资深教学老师独家创作,致力于为大家讲解清晰MySQL数据库相关知识点,含有丰富的代码案例及讲解。如果感觉对大家有帮助的话,可以 【关注】 持续追更~

文末有本文重点总结,技术类问题,也欢迎大家和我们沟通交流!

mysqlsql语句优化总结,mysql慢sql分析及优化

前言

从今天开始本系列文章就带各位小伙伴学习数据库技术。 数据库技术是Java开发中必不可少的一部分知识内容。也是非常重要的技术。本系列教程由浅入深, 全面讲解数据库体系。非常适合零基础的小伙伴来学习。

全文大约 1240】 字,不说废话,只讲可以让你学到技术、明白原理的纯干货!本文带有丰富案例及配图视频,让你更好的理解和运用文中的技术概念,并可以给你带来具有足够启迪的思考...

一. 慢查询日志

SQL是我们和数据库交流最重要的部分,所以我们在调优的时候,需要花费的大量时间就在SQL调优上面。

慢查询日志按照的经验来说就是发现系统中查询慢的SQL语句的有效手段之一。

常见的分析手段有慢查询日志,EXPLAIN 分析查询,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。

1. 开启慢查询日志

在配置文件my.cnf或my.ini中在[mysqld]一行下面加入两个配置参数:

mysqlsql语句优化总结,mysql慢sql分析及优化

log-slow-queries 参数为慢查询日志存放的位置,一般这个目录要有mysql的运行帐号的可写权限,一般都将这个目录设置为mysql的数据存放目录;

long_query_time=5中的5表示查询超过五秒才记录;

还可以在my.cnf或者my.ini中添加 log-queries-not-using-indexes 参数,表示记录下没有使用索引的查询。

2. 慢查询分析

我们可以通过打开log文件查看得知哪些SQL执行效率低下 ,从日志中,可以发现查询时间超过5秒的SQL,而小于5秒的没有出现在此日志中。

如果慢查询日志中记录内容很多,可以使用 mysqldumpslow工具 (MySQL客户端安装自带)来对慢查询日志进行分类汇总。 mysqldumpslow 对日志文件进行了分类汇总,显示汇总后摘要结果。

进入log的存放目录,运行:

mysqlsql语句优化总结,mysql慢sql分析及优化

mysqldumpslow命令:

mysqlsql语句优化总结,mysql慢sql分析及优化

这会输出记录次数最多的10条SQL语句,其中:

-s: 是表示按照何种方式排序,c、t、l、r分别是按照记录次数、时间、查询时间、返回的记录数来排序,ac、at、al、ar:表示相应的倒叙。

-t: 是top n的意思,即为返回前面多少条的数据。

-g: 后边可以写一个正则匹配模式,大小写不敏感的。

来给各位小伙伴举个栗子:

mysqlsql语句优化总结,mysql慢sql分析及优化

得到返回记录集最多的10个查询。

使用mysqldumpslow命令可以非常明确的得到各种我们需要的查询语句,对MySQL查询语句的监控、分析、优化是MySQL优化非常重要的一步。开启慢查询日志后,由于日志记录操作,在一定程度上会占用CPU资源影响mysql的性能,但是可以阶段性开启来定位性能瓶颈。

二. 结语

最后在这里对本文核心要点进行总结:

慢查询日志是发现系统中查询慢的SQL语句的有效方式之一,需要熟练运用,慢查询日志默认是不开启的,需要各位小伙伴手动开启。开启后需要重启MySQL服务才可以生效。

往期精彩推荐:

MySQL优化思路及方向

MySQL索引高级进阶详解-玩转MySQL数据库

深谈MySQL数据库索引进阶

MySQL索引基础入门,一篇讲清楚

更多技术类干货/IT资讯/程序员信息,关注 @千锋教育