刷题刷出新高度,偷偷领先!偷偷领先!偷偷领先! 关注我们,悄悄成为最优秀的自己!

面试题

MYSQL查询慢的主要原因有哪些 ?如何分析慢查询 ?

使用微信搜索喵呜刷题,轻松应对面试!

答案:

  • 通常所说查询慢即响应时间长。一个查询的生命周期:从客户端,到服务器,然后服务器进行解析、执行,最后返回结果给客户端。
  • 时间消耗。网络,CPU计算,执行计划,锁等待,调用底层存储引擎获取数据,I/O操作,系统调用等等。
  • 查询慢原因。不必要的额外操作,某些操作被额外的重复了很多次,某些操作被执行的太慢等等。
  • 访问的数据的太多。
  • 索引设置不合理,导致全表扫描。
  • 服务器设置不合理,造成资源紧张等原因。

如何分析慢查询?

  1. 确认SQL是否查询了大量的不必要数据。也就是太多的行,非必要的列。(PHP)

SELECT * FROM warning_event

  1. 确认服务器层是否分析了大量超过所需的行。

如何判断?估算响应时间、扫描的行数和返回的行数(EXPLAIN)

SELECT * FROM warning_event WHERE assailant_id=1

EXPLAIN SELECT 1 FROM warning_event WHERE event_code=’1′ limit 1;

+————-+——+——+——+————-+

| select_type | type | ref | rows | Extra |

+————-+——+——+——+————-+

| SIMPLE | ALL | NULL | 285 | Using where |

+————-+——+——+——+————-+

event_code增加索引

+————-+——+——-+——+————————–+

| select_type | type | ref | rows | Extra |

+————-+——+——-+——+————————–+

| SIMPLE | ref | const | 1 | Using where; Using index |

+————-+——+——-+——+————————–+

SHOW FULL PROCESSLIST

比较重要的一个字段:State

Query:正在执行查询或者发送数据到客户端

Locked:等待锁

Analyzing and statistics:收集统计信息,生成查询执行计划

Copying to tmp table [on disk]:正在执行的查询将结果集放到临时表中,GROUP BY操作、文件排序操作、UNION操作,on disk这个临时表在硬盘上

Sorting result:对结果集进行排序



创作类型:
原创

本文链接:MYSQL查询慢的主要原因有哪些 ?如何分析慢查询 ?

版权声明:本站点所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明文章出处。

让学习像火箭一样快速,微信扫码,获取考试解析、体验刷题服务,开启你的学习加速器!

分享考题
share