MySQL中explain的使用

当我们在查询过程中遇到慢sql的时候会使用explain进行查找原因

慢sql的查找

首先开启慢sql日志记录

set global slow_query_log=on;

在系统中默认的慢sql执行时间为10秒(慢sql还与另一个因素有关系就是查询的记录数但默认值0)

设置慢sql时间指令

set  long_query_time=xx; (以秒为单位)

满足条件的慢sql会被存放到/var/lib/mysql目录下的以主机名开头的  主机名-slow.log 文件中

我们可以通过mysqldumpslow指令来查看(这个指令不是sql命令在mysql目录下执行即可)

mysqldumpslow -s t -t 5 -a /var/lib/mysql/node0-slow.log

-s 表示以什么条件进行查看  t表示按执行时间进行查看

-t 表示查看的命令数  -a表是显示慢sql语句中字段的具体类型

explain的参数组成 

table:在sql语句中有几张表explain的记录就会有几条

id:主要来记录select语句如果在一个语句中有两个select操作就会有2个id一个是1一个2 id越大越先执行在一条语句中id越小越好(有时候优化器会对查询语句进行优化,子查询有两个select会被优化成多表查询)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值