**:
mysql的檢視執行計畫的語句很簡單,explain+你要執行的sql語句就ok了。
舉乙個例子
explain select * from employees where employees.gender='m'
返回的結果如下:
這些結果都代表什麼?
id是一組數字,表示查詢中執行select子句或操作表的順序。
如果id相同,則執行順序從上至下。
如果是子查詢,id的序號會遞增,id越大則優先順序越高,越先會被執行。
id如果相同,則可以認為是一組,從上往下順序執行,所有組中,id越高,優先順序越高,越容易執行。
selecttype有******,primary,subquery,derived(衍生),union,unionresult。
******表示查詢中不包含子查詢或者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上有乙個索引。使用如下語句
1
explain
select
gender
from
employees
則結果如下:1 ****** employees index ind_gen 1 300695 using index
1
explain
select
first_name
from
employees
則結果如下 1
******
employees
all
300695
keylen表示索引所使用的位元組數,可以通過該列結算查詢中使用的索引長度
ref表示上述表的鏈結匹配條件,即哪些列或常量可被用於查詢索引列上的值。
rows表示根據mysql表統計資訊及索引選用情況,估算找到所需記錄要讀取的行數。
extra表示不在其他列並且也很重要的額外資訊。
using index表示在相應的select中使用了覆蓋索引。
usingwhere表示儲存引擎搜到記錄後進行了後過濾(post-filter),如果查詢未能使用索引,usingwhere的作用只是提醒我們mysql要用where條件過濾z結果集。
using temporay表示用臨時表來儲存結果集,常見於排序和分組查詢。
usingfilesort,mysql中無法用索引完成的排序成為檔案排序。
關於覆蓋索引的一些概念如下:
mysql可以利用索引返回select列表中的字段,而不必根據索引再次讀取資料檔案 包含所有滿足查詢需要的資料的索引稱為 覆蓋索引(covering index) 如果要使用覆蓋索引,一定要注意select列表中只取出需要的列,不可select *,因為如果將所有字段一起做索引會導致索引檔案過大,查詢效能下降mysq的執行計畫有一定侷限性直接引用了
•explain不會告訴你關於觸發器、儲存過程的資訊或使用者自定義函式對查詢的影響情況
•explain不考慮各種cache
•explain不能顯示mysql在執行查詢時所作的優化工作
•部分統計資訊是估算的,並非精確值
•expalin只能解釋select操作,其他操作要重寫為select後檢視執行計畫
增加乙個參考鏈結
總結一下,本文主要是說明了mysql執行計畫中幾個欄位的意思,包括id,select_type,table,type,possable_keys,key,key_len,ref,rows 和extra。
mysql執行計畫 MySQL 執行計畫
1.執行計畫的定義 什麼是執行計畫 查詢計畫 呢?執行計畫就是一系列的操作步驟。sql是宣告性語言,它只告訴資料庫要查詢什麼,但並不告訴資料庫如何去查。資料庫所要做的就是基於演算法和統計資訊計算出一條最佳的訪問路徑。這個工作是由優化器來完成的。優化器會比較不同的執行計畫,然後選擇其中最優的一套。2....
mysql 生成執行計畫 MySQL執行計畫
和很多其他關係型資料庫不通,mysql並不會在生成查詢位元組碼來執行查詢。mysql生成查詢的一棵指令樹,然後通過儲存引擎執行完成這棵指令樹並返回結果。最終的執行計畫包含了重構查詢的全部資訊。如果某個查詢執行explain extended 之後,在執行show warnings,就可以看到重構出的...
mysql 查詢執行計畫 MySql執行計畫的檢視
一。什麼是資料庫執行計畫 利用乙個sql語句,你可能要server取出所有news表中的資訊.當server收到的這條sql的時候,第一件事情並不是解析它.如果這條sql沒有語法錯誤,server才會繼續工作.server會決定最好的計算方式.server會選擇,是讀整個news表好呢,還是利用索引...