1. 程式人生 > >如何看懂mysql explain

如何看懂mysql explain

這些結果都代表什麼?

id是一組數字,表示查詢中執行select子句或操作表的順序。

如果id相同,則執行順序從上至下。

如果是子查詢,id的序號會遞增,id越大則優先順序越高,越先會被執行。

id如果相同,則可以認為是一組,從上往下順序執行,所有組中,id越高,優先順序越高,越容易執行。

selecttype有simple,primary,subquery,derived(衍生),union,unionresult。

simple表示查詢中不包含子查詢或者union。

當查詢中包含任何複雜的子部分,最外層的查詢被標記成primary。

在select或where列表中包含了子查詢,則子查詢被標記成subquery。

在from的列表中包含的子查詢被標記成derived。

若第二個select出現在union後,則被標記成union,若union在from子句的子查詢中,外層的select被標記成derived。

從union表獲取結果的select被標記成union result。

type叫訪問型別,表示在表中找到所需行的方式,常見型別有all,index,range,ref,eq_ref,const,system,NULL 效能從做至右由差至好。

ALL,即full table scan,mysql將遍歷全表來找到所需要的行。

index為full index scan,只遍歷索引樹。

range表示索引範圍掃描 ,對索引的掃描開始於一點,返回匹配的值域的行,常見於between,<,>的查詢。

ref為非唯一性索引掃描,返回匹配某個單獨值的所有行,常見於非唯一索引即唯一索引的非唯一字首進行的查詢。

eq_ref表示唯一性索引掃描,對於每個索引鍵,表中只有一條記錄與之匹配,常見於主鍵或者唯一索引掃描。

const,system表示當對查詢部分進行優化,並轉化成一個常量時,使用這些型別訪問。比如將主鍵置於where列表中,mysql就能把該查詢置成一個常量。system是const的一個特例,當查詢表中只有一行的情況下使用的是system。

NULL表示在執行語句中,不用查表或索引。

possiblekey表示能使用哪個索引在表中找到行,查詢涉及到的欄位上若存在索引,則該索引被列出,但不一定被查詢使用。

key表示查詢時使用的索引。若查詢中使用了覆蓋索引,則該索引僅出現在key中舉個例子

employee中gender上有一個索引。使用如下語句

EXPLAIN SELECT gender from employees
則結果如下:1 SIMPLE employees index IND_GEN 300695 Using index
EXPLAIN SELECT first_name from employees
則結果如下  1 SIMPLE employees ALL 300695  keylen表示索引所使用的位元組數,可以通過該列結算查詢中使用的索引長度 ref表示上述表的連結匹配條件,即哪些列或常量可被用於查詢索引列上的值。 rows表示根據mysql表統計資訊及索引選用情況,估算找到所需記錄要讀取的行數。 extra表示不在其他列並且也很重要的額外資訊。 using index表示在相應的select中使用了覆蓋索引。 usingwhere表示儲存引擎搜到記錄後進行了後過濾(POST-FILTER),如果查詢未能使用索引,usingwhere的作用只是提醒我們mysql要用where條件過濾z結果集。 using temporay表示用臨時表來儲存結果集,常見於排序和分組查詢。 usingfilesort,mysql中無法用索引完成的排序成為檔案排序。 mysq的執行計劃有一定侷限性直接引用了 •EXPLAIN不會告訴你關於觸發器、儲存過程的資訊或使用者自定義函式對查詢的影響情況 •EXPLAIN不考慮各種Cache •EXPLAIN不能顯示MySQL在執行查詢時所作的優化工作 •部分統計資訊是估算的,並非精確值 •EXPALIN只能解釋SELECT操作,其他操作要重寫為SELECT後檢視執行計劃

總結一下,本文主要是說明了mysql執行計劃中幾個欄位的意思,包括id,select_type,table,type,possable_keys,key,key_len,ref,rows 和Extra。