1. explain extended select ….. 將執行計劃反編譯成SELECT 語句,運行 show warnings 可得到被mysql優化器優化后的查詢語句。 2. explain partitions select …. 用于分區表的EXPLAIN 3.執行計劃包含的信息 id select_type table type possible_keys key
1. explain extended select …..?
將執行計劃反編譯成SELECT 語句,運行 show warnings 可得到被MYSQL優化器優化后的查詢語句。
2. explain partitions select ….
用于分區表的EXPLAIN
3.執行計劃包含的信息
id????? select_type???? table??? type?? possible_keys?? key?? key_len? ref?? rows?? extra
3.1 id: 包含一組數字,表示查詢中執行select 子句或操作表的順序。
id如果相同,可以認為是一組,從上往下順序執行;在所有組中,ID值越大,優先級越高,越先執行。
3.2 select_type : 表示查詢中每個select 子句的類型(簡單OR復雜)
a. simple:? 查詢中不包含子查詢或者union
b. 查詢中若包含任何復雜的子部份,最外層查詢則被標記為:primary
c. 在SELECT或WHERE 列表中包含了子查詢,該子查詢被標記為:SUBQUERY
d.在FROM 列表中包含的子查詢被標記為:DERIVED
e. 若第二個SELECT出現在UNION之后,則被標記為UNION 若UNION包含在FROM子句的子查詢中,外層SELECT將被標記為:DERIVED
f. 從UNION表獲取結果的SELECT被標記為:UNION RESULT
3.3 type: 表示MYSQL 在表中找到所需行的方式,又稱“訪問類型”,常見類型如下:
all????? index??????? range????? ref??? eq_ref?? const, system??? null
由左至右,由最差到最好
a. ALL: FULL TABLE SCAN , MYSQL 將遍歷全表以找到匹配的行
b. INDEX: FULL INDEX SCAN, INDEX與ALL區別為INDEX類型只遍歷索引
c. RANGE:索引范圍掃描,對索引的掃描開始于某一點,返回匹配值域的行,常見于 between, 等的查詢。
d.REF: 非唯一性索引掃描,返回匹配某個單獨值的所有行,常見于使用非唯一索引即唯一索引的非唯一前綴進行的查找。
e.EQ_REF: 唯一性索引掃描,對于每個索引鍵,表中只有一條記錄與之匹配。常見于主鍵或唯一索引掃描。
f. CONST, SYSTEM: 當MYSQL 對查詢某部份進行優化,并轉換為一個常量時,使用這些類型訪問,如將主鍵置于WHERE列表中,MYSQL就能將該查詢轉換成一個常量。 SYSTEM是CONST類型的特例,當查詢的表只有一行的情況下,使用SYSTEM
g.NULL: MYSQL 在優化過程中分解語句,執行時甚至不用訪問表或索引。
3.4 possible_keys
指出MYSQL 能使用哪個索引在表中找到行,查詢涉及到的字段上若存在索引,則該索引將被列出,但不一定被查詢使用。
3.5 key
顯示MYSQL 在查詢中實際使用的索引,若沒有使用索引,顯示為NULL, 如果用了覆蓋索引,則該索引公出現在KEY列表中。
3.6 key_len
表示索引中使用的字節數,可通過該列計算查詢中使用的索引的長度。key_len顯示的值為索引字段的最大可能長度,并非實際使用長度,即KEY_LEN是根據表定義計算而得,不是通過表內檢索出的。
3.7 ref
表示上述表的連接匹配條件,即哪些列或常量被用于查找索引列上的值。
3.8 rows
表示MYSQL 根據表統計信息及索引選用情況,估算的找到所需的記錄所需要讀取的行數。
3.9 extra: 包含不適合在其他列中顯示但十分重要的額外信息。
A. USING INDEX: 該值表示相應的SELECT操作中使用了覆蓋索引(COVERING INDEX)
覆蓋索引:MYSQL 可以利用索引返回SELECT列表中的字段,而不必根據索引再次讀取數據文件。
包含所有滿足查詢需要的數據的索引稱為覆蓋索引
注:如果要使用覆蓋索引,一定要SELECT列表中只取出需要的列,不可SELECT *,因為如果將所有字段一起做索引會導致索引文件過大,查詢性能下降。
USING WHERE: 表示MYSQL 服務器在存儲引擎收到記錄后進行“后過濾”,如果查詢未能使用索引, USING WHERE 的作用只是提醒我們MYSQL將用WHERE 子句來過濾結果集。
USING TEMPORARY: 表示MYSQL 需要使用臨時表來存儲結果集,常見于排序和分組查詢。
USING FILESORT: MYSQL 中無法利用索引完成的排序操作稱為“文件排序”
4. MYSQL 執行計劃的局限:
4.1EXPLAIN不會告訴你關于觸發器、存儲過程的信息或用戶自定義函數對查詢的影響情況
4.2 EXPLAIN 不考慮各種CACHE
4.3 EXPLAIN 不能顯示MYSQL在執行查詢時所作的優化工作。
4.4 部份統計信息是估算的,并非精確值。
4.5EXPLAIN 只能解釋SELECT 操作,其他操作要重寫為SELECT后查看執行計劃