关于慢查询

概述

慢查询是指只要存在查询的地方就会有慢查询的问题,如关系型数据库(mysql、oracle)和非关系型数据库(nosql,redis、MongoDB等),区别是它们设置慢查询的命令及方式不同而已。下面以中小型企业常用的mysql为例来说明,在分析mysql查询性能可以使用explain分析sql语句的执行过程,还可以设置mysql记录sql语句的执行时间长的语句,简单说就是超过指定时间长的查询语句就叫“慢查询”。mysql会将查询慢的语句记录到log中方便进行以后sql语句的优化。

慢查询怎么解决sql慢的问题

慢查询是记录sql语句的,并不会自动帮助您解决sql查询慢的问题,它将sql执行慢的语句存储下了,以便于你分析来找sql执行慢的原因。

为什么会产生慢查询?

我们在执行一条sql时,它的请求过程大致是,客户端-->服务端,服务端执行查询,在将查询的结果返回给客户端,这个过程都会产生耗时,其实主要的耗时发生在服务端执行sql进行查询数据产生的耗时,是因为查询数据需要在不同的地方耗时,比如网路、CPU计算及执行计划等,尤其是向底层存储引擎检索数据的调用操作。可以看出查询慢主要是耗费在执行查询所耗费的时间。

查看mysql是否开启慢查询

show variables like "%slow_query%"

默认情况下慢查询是关闭的,慢查询的日志如果没有设置,默认为空hostname-slow.log.

查看mysql慢查询的超时时间

show variables like "%long_query_time%"

默认时间是10s。

设置开启慢查询及超时间

方式一:

set global slow_query_log=ON
set global long_query_time=5

方式二:

修改my.cnf 文件

[mysqld]

slow_query_log = ON

long_query_time = 5

重启mysql

测试慢查询

SELECT SLEEP(12);

查看慢查询日志是否生成这条语句

可以看到使用的库、运行的时间戳及慢查询sql。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值