慢查询原因
一条sql偶尔查询很慢
原因
- 数据库更新频繁,redo log buf很快满了,只能先暂停其他操作,将redo log buf同步写到磁盘上时,这时候查询只能等待写磁盘完成了。
- 查询涉及到的表或行被加锁了,只能等待锁被释放。
一条sql一致查询很慢
应该是sql书写有问题了。
原因
- 字段未创建索引
- 索引失效。索引失效有很多原因。
- 数据库选错索引。数据库的统计信息不准确,选错了索引,analyze 表重新统计信息。或者sql里强制使用某个索引。
索引失效的情况
where、group by、order by等条件使用了运算符、函数
like '%XX' 或'%XX%',即不是'XX%'
- 两个列的编码不一致,如utf8、uft8mb4
隐式转换
:两个列的数据类型不一致。mysql支持字符串转数字,隐式转换,字符型字段 = 数字,会将字符型字段转为数字来比较,字段不是原本的字符型了or有一边的列无索引,即使都有索引,优化器也要根据情况选择是否使用索引
联合索引不符合最左原则
慢查询排查
- 开启慢查询日志slow_query_log=1,并设置慢查询时长标准long_query_time
- 查看慢查询日志,使用mysqldumpslow命令