mysql 如何檢視sql語句執行時間和效率

2021-09-11 05:17:52 字數 1484 閱讀 9204

檢視執行時間

1 show profiles; 

2 show variables;檢視profiling 是否是on狀態; 

3 如果是off,則 set profiling = 1; 

4 執行自己的sql語句; 

5 show profiles;就可以查到sql語句的執行時間;

檢視操作了多少行

在sql語句前面加上 explain就可以了;

explain select * from event;  

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

| id | select_type | table | type | possible_keys | key | key_len | ref | rows | extra |  

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

| 1 | ****** | event | all | null | null | null | null | 13 | |  

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

1 row in set (0.00 sec) 

各個屬性的含義

idselect查詢的序列號

select_type

select查詢的型別,主要是區別普通查詢和聯合查詢、子查詢之類的複雜查詢。

table

輸出的行所引用的表。

type

聯合查詢所使用的型別。

type顯示的是訪問型別,是較為重要的乙個指標,結果值從好到壞依次是:

system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > all

一般來說,得保證查詢至少達到range級別,最好能達到ref。

possible_keys

指出mysql能使用哪個索引在該表中找到行。如果是空的,沒有相關的索引。這時要提高效能,可通過檢驗where子句,看是否引用某些字段,或者檢查字段不是適合索引。

key顯示mysql實際決定使用的鍵。如果沒有索引被選擇,鍵是null。

key_len

顯示mysql決定使用的鍵長度。如果鍵是null,長度就是null。文件提示特別注意這個值可以得出乙個多重主鍵裡mysql實際使用了哪一部分。

ref顯示哪個欄位或常數與key一起被使用。

rows

這個數表示mysql要遍歷多少資料才能找到,在innodb上是不準確的。

extra

如果是only index,這意味著資訊只用索引樹中的資訊檢索出的,這比掃瞄整個表要快。

如果是where used,就是使用上了where限制。

如果是impossible where 表示用不著where,一般就是沒查出來啥。

SQL Server如何檢視SQL語句的執行時間

在sql server資料庫中,如何才能檢視sql語句的執行時間呢?本文將為您介紹查詢方法,供您參考,希望對您能夠有所幫助。下面這種是sql server中比較簡單的查詢sql語句執行時間方法,通過查詢前的時間和查詢後的時間差來計算的 declare begin date datetime decl...

SQL Server如何檢視SQL語句的執行時間

在sql server資料庫中,如何才能檢視sql語句的執行時間呢?本文將為您介紹查詢方法,供您參考,希望對您能夠有所幫助。下面這種是sql server中比較簡單的查詢sql語句執行時間方法,通過查詢前的時間和查詢後的時間差來計算的 declare begin date datetime decl...

SQL Server如何檢視SQL語句的執行時間

在sql server資料庫中,如何才能檢視sql語句的執行時間呢?本文將為您介紹查詢方法,供您參考,希望對您能夠有所幫助。下面這種是sql server中比較簡單的查詢sql語句執行時間方法,通過查詢前的時間和查詢後的時間差來計算的 declare begin date datetime decl...