mysql 慢sql 十几秒_Mysql数据库的慢sql优化步骤

Mysql数据库的慢sql优化步骤

慢sql优化步骤:

先查看慢日志,获得具体哪条sql语句是慢sql。

再使用explain sql语句,进行对慢sql分析。

修改sql语句,或者增加索引。

在数据库可视化工具中,显示有关慢日志的信息:

show variables like '%quer%';

Image.png

主要是查看这三个字段的信息:

long_query_time:sql执行多久才算慢sql,默认是10s;

slow_query_log:慢日志是否开启,默认是OFF;

slow_query_log_file:慢日志存放的位置

想要永久的修改属性,那么就要去数据库的安装目录去修改my.ini文件,linux系统的话,那就就是my.cnf文件。

若只是想在单次连接中(下次重启mysql服务就失效)修改属性,那么可以直接使用set global 属性名=修改属性值;注意:在执行了该条语句之后,需要用终端重新连接mysql数据库。

1596534119268-Image.png

将long_query_time设置回1s;

执行一条sql;查找单个字段,不走索引;(表中的数据有40万条左右)

1596534119269-Image.png

再打开慢日志查看最新一条慢sql:

1596534119270-Image.png

可以看见query_time是1.8s,所以就是刚刚执行的那条sql就是慢sql了。

接着使用explain分析慢sql;

主要分析type和extra字段属性;如果type为index或者all那么走的就是全表查询,很大可能性是慢sql;

还有一个extra字段,如果是using filesort:文件排序(没有利用索引排序的操作),或是using temporary:在对查询结果排序时使用了临时表,常见的order by和分组group by;

优化慢sql:让sql走索引;修改sql语句。

修改上条sql语句,将motto字段设置成索引字段:

alter table person_info_large add index idx_mot(motto);

1596534119271-Image.png

查询时间小于1s;不计入慢日志;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值