explain命令在解決資料庫效能上是第一推薦使用命令,大部分的效能問題可以通過此命令來簡單的解決,explain可以用來檢視sql語句的執行效 果,可以幫助選擇更好的索引和優化查詢語句,寫出更好的優化語句。
explain語法:explain select … from … [where …]
例如:explain select * from news;
輸出:| id | select_type | table | type | possible_keys | key | key_len | ref | rows | extra |
下面對各個屬性進行了解:
1、id:這是select的查詢序列號
2、select_type:select_type就是select的型別,可以有以下幾種:
******:簡單select(不使用union或子查詢等)3、table:顯示這一行的資料是關於哪張表的primary:最外面的select
union:union中的第二個或後面的select語句
dependent union:union中的第二個或後面的select語句,取決於外面的查詢
union result:union的結果。
subquery:子查詢中的第乙個select
dependent subquery:子查詢中的第乙個select,取決於外面的查詢
derived:匯出表的select(from子句的子查詢)
4、type:這列最重要,顯示了連線使用了哪種類別,有無使用索引,是使用explain命令分析效能瓶頸的關鍵項之一。
結果值從好到壞依次是:5、possible_keys:列指出mysql能使用哪個索引在該表中找到行system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > all
一般來說,得保證查詢至少達到range級別,最好能達到ref,否則就可能會出現效能問題。
6、key:顯示mysql實際決定使用的鍵(索引)。如果沒有選擇索引,鍵是null
7、key_len:顯示mysql決定使用的鍵長度。如果鍵是null,則長度為null。使用的索引的長度。在不損失精確性的情況下,長度越短越好
8、ref:顯示使用哪個列或常數與key一起從表中選擇行。
9、rows:顯示mysql認為它執行查詢時必須檢查的行數。
distinct其他一些tip:一旦mysql找到了與行相聯合匹配的行,就不再搜尋了
not exists
mysql 優化了left join,一旦它找到了匹配left join標準的行,
就不再搜尋了
range checked for each
record(index map:#)
沒有找到理想的索引,因此對於從前面表中來的每一 個行組合,mysql檢查使用哪個索引,並用它來從表中返回行。這是使用索引的最慢的連線之一
using filesort
看 到這個的時候,查詢就需要優化了。mysql需要進行額外的步驟來發現如何對返回的行排序。它根據連線型別以及儲存排序鍵值和匹配條件的全部行的行指標來 排序全部行
using index
列資料是從僅僅使用了索引中的資訊而沒有讀取實際的行動的表返回的,這發生在對錶 的全部的請求列都是同乙個索引的部分的時候
using temporary
看到這個的時候,查詢需要優化了。這 裡,mysql需要建立乙個臨時表來儲存結果,這通常發生在對不同的列集進行order by上,而不是group by上
using where
使用了where從句來限制哪些行將與下一張表匹配或者是返回給使用者。如果不想返回表中的全部行,並且連線型別all或index, 這就會發生,或者是查詢有問題
當type 顯示為 「index」 時,並且extra顯示為「using index」, 表明使用了覆蓋索引。
的士特囉嗦司機
出處:
EXPLAIN分析SQL語句
使用explain關鍵字可以模擬優化器執行sql查詢語句,從而知道mysql是如何處理你的sql語句,可以幫助選擇更好的索引和寫出更優化的查詢語句。explain 的每個輸出行包括下面的列 select查詢的序列號,包含一組數字,表示查詢中執行select子句或操作表的順序。有三種情況 select...
EXPLAIN分析SQL語句
explain顯示了mysql如何使用索引來處理select語句以及連線表。使用explain關鍵字可以模擬優化器執行sql查詢語句,從而知道mysql是如何處理你的sql語句的,繼而可以幫助選擇更好的索引和寫出更優化的查詢語句。explain select的sql語句 上圖顯示了explain的結...
Explain分析sql語句執行效率
使用explain命令會有以下屬性輸出 1 id 這是select的查詢序列號 2 select type select type就是select的型別 1.簡單select 不使用union或者子查詢等 2.primsry union中的第二個或後面的select語句 3.dependent un...