mysql運維與分析-效能分析工具-show profiles
http://www.cnblogs.com/happySmily/p/5943311.html
作用範圍
這個命令只是在本會話內起作用,即無法分析本會話外的語句。
開啟分析功能後,所有本會話中的語句都被分析(甚至包括執行錯誤的語句),除了SHOW PROFILE和SHOW PROFILES兩句本身。
為了驗證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要你自己按回車執行,這樣就不準了。