摘自: https://blog.csdn.net/zhuzaijava/article/details/77935200java
爲了驗證select 1 與 select 1 from tableName 與 select * from tableName的執行效率,須要測試一下各自執行的時間。因而總結一下,查看mysql語句運行時間的方法。mysql
方法一: show profiles。sql
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是用戶變量,每次都得從新啓用。.net
查看方法: show variables like "%pro%";命令行
設置開啓方法: set profiling = 1;blog
再次查看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要你本身按回車執行,這樣就不許了。