mysql sql執行慢 分析過程

2021-08-08 02:02:33 字數 1606 閱讀 1385

為了驗證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要你自己按回車執行,這樣就不准了。

mysql sql執行慢示例分析

mysql create table table a id int 11 not null,b varchar 10 default null,primary key id key b b engine innodb 執行sql,mysql select from table a where b 1...

MySQL SQL執行計畫分析

當我們的系統上線後資料庫的記錄不斷增加,之前寫的一些sql語句或者一些orm操作效率變得非常低。我們不得不考慮sql優化,sql優化大概是這樣乙個流程 1.定位執行效率低的sql語句 定位 2.分析為什麼這段sql執行的效率比較低 分析 3.最後根據第二步分析的結構採取優化措施 解決 而explai...

MySQL SQL執行計畫

sql的執行 通訊階段 查詢快取 解析器進行驗證解析,基於語法戒心和詞法解析得到解析樹 優化器,優化執行階段找到sql的最優執行方式 執行器執行計畫 用explain或者desc檢視sql的執行計畫 執行計畫引數 id sql執行的順序,值大的先執行,id一樣的話,按照順序從上至下執行 select...