覆蓋索引: MySQL可以利用索引返回select列表中的字段,而不必根據索引再次讀取數據文件 包含所有滿足查詢需要的數據的索引稱為 覆蓋索引(Covering Index) 如果要使用覆蓋索引,一定要注意select列表中只取出需要的列,不可select *,因為如果將所有字段一起做索引會導致索引文件過大,查詢性能下降
EXPLAIN查看執行計划的一些局限:
EXPLAIN不會告訴你關於觸發器、存儲過程的信息或用戶自定義函數對查詢的影響情況
EXPLAIN不考慮各種Cache
EXPLAIN不能顯示MySQL在執行查詢時所作的優化工作
部分統計信息是估算的,並非精確值
EXPALIN只能解釋SELECT操作,其他操作要重寫為SELECT后查看執行計划
*************************** 1. row ***************************
id: 1 <br> select_type: SIMPLE
table: t1
type: ref
possible_keys: idx_customer_no
key: idx_customer_no
key_len: 99
ref: const
rows: 1
Extra: Using index condition; Using where 1 row in set (0.00 sec)
id:是一組數字,表示查詢中執行select子句或操作表的順序。 如果id相同,則執行順序從上至下; 如果是子查詢,id的序列號會遞增,id越大則優先級越高,越先會被執行。 id如果相同,則可以認為是一組,從上往下順序執行,所有組中,id越高,優先級越高,越容易執行。
select_type:取值有simple,primary,subquery,derived,union,unionresult
simple:表示查詢中不包含子查詢或者union
primary:當查詢中包含任何復雜的子部分,最外層的查詢被標記成primary
subquery:在select或where列表中包含了子查詢,則子查詢被標記成subquery
derived:在from的列表中包含的子查詢被標記成derived
union:若第二個select出現在union后,則被標記成union,若union在from子句的子查詢中,外層的select被標記成derived
unionresult:從union表獲取結果的select被標記成union result
table:顯示這一行的數據是關於哪張表的
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中。
key_len:表示索引所使用的字節數,可以通過該列結算查詢中使用的索引長度
ref:表示上述表的鏈接匹配條件,即哪些列或常量可被用於查找索引列上的值。
rows:表示根據mysql表統計信息及索引選用情況,估算找到所需記錄要讀取的行數。
extra:表示不在其他列並且也很重要的額外信息。
using index表示相應的select中使用了覆蓋索引。
usingwhere表示存儲引擎搜到記錄后進行了后過濾(POST-FILTER),如果查詢未能使用索引,usingwhere的作用只是提示我們mysql要用where條件過濾Z結果集。
using temporay表示臨時表來存儲結果集,常見於排序和分組查詢。
using filesort mysql中無法用索引完成的排序成為文件排序
extra值參考列表
distinct: 當mysql找到第一條匹配的結果值時,就停止該值的查詢,然后繼續該列其他值的查詢。