mysql sql執行慢 分析過程


摘自: https://blog.csdn.net/zhuzaijava/article/details/77935200

 

為了驗證select 1 與 select 1 from tableName 與 select * from tableName的執行效率,需要測試一下各自執行的時間。於是總結一下,查看mysql語句運行時間的方法。

方法一: show profiles。

1. Show profiles是5.0.37之后添加的,要想使用此功能,要確保版本在5.0.37之后。

     Query Profiler是MYSQL自帶的一種query診斷分析工具,通過它可以分析出一條SQL語句的性能瓶頸在什么地方。通常我們是使用的explain,以及slow query log都無法做到精確分析,

     但是Query Profiler卻可以定位出一條SQL語句執行的各種資源消耗情況,比如CPU,IO等,以及該SQL執行所耗費的時間等。

     查看數據庫版本方法:show variables like "%version%";  或者  select version();

    

2.確定支持show profile 后,查看profile是否開啟,數據庫默認是不開啟的。變量profiling是用戶變量,每次都得重新啟用。

   查看方法: show variables like "%pro%";

   設置開啟方法: set profiling = 1;

   

   再次查看show variables like "%pro%"; 已經是開啟的狀態了。

3.可以開始執行一些想要分析的sql語句了,執行完后,show profiles;即可查看所有sql的總的執行時間。

  

  show profile for query 1 即可查看第1個sql語句的執行的各個操作的耗時詳情。

  

 show profile cpu, block io, memory,swaps,context switches,source for query 6;可以查看出一條SQL語句執行的各種資源消耗情況,比如CPU,IO等

 show profile all for query 6 查看第6條語句的所有的執行信息。

 測試完畢后,關閉參數:

mysql> set profiling=0

方法二: timestampdiff來查看執行時間。

這種方法有一點要注意,就是三條sql語句要盡量連一起執行,不然誤差太大,根本不准

set @d=now();
select * from comment;
select timestampdiff(second,@d,now());

如果是用命令行來執行的話,有一點要注意,就是在select timestampdiff(second,@d,now());后面,一定要多copy一個空行,不然最后一個sql要你自己按回車執行,這樣就不准了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM