mysql 慢查询原因 排查 优化

慢查询原因

一条sql偶尔查询很慢
原因

  • 数据库更新频繁,redo log buf很快满了,只能先暂停其他操作,将redo log buf同步写到磁盘上时,这时候查询只能等待写磁盘完成了。
  • 查询涉及到的表或行被加锁了,只能等待锁被释放。

一条sql一致查询很慢
应该是sql书写有问题了。
原因

  • 字段未创建索引
  • 索引失效。索引失效有很多原因。
  • 数据库选错索引。数据库的统计信息不准确,选错了索引,analyze 表重新统计信息。或者sql里强制使用某个索引。

索引失效的情况

  • where、group by、order by等条件使用了运算符、函数
  • like '%XX' 或'%XX%',即不是'XX%'
  • 两个列的编码不一致,如utf8、uft8mb4
  • 隐式转换:两个列的数据类型不一致。mysql支持字符串转数字,隐式转换,字符型字段 = 数字,会将字符型字段转为数字来比较,字段不是原本的字符型了
  • or有一边的列无索引,即使都有索引,优化器也要根据情况选择是否使用索引
  • 联合索引不符合最左原则

慢查询排查

  1. 开启慢查询日志slow_query_log=1,并设置慢查询时长标准long_query_time
  2. 查看慢查询日志,使用mysqldumpslow命令
  • 2
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值