mysql 執行計畫不對 Mysql執行計畫分析

2021-10-18 21:01:37 字數 1078 閱讀 6263

mysql執行計畫分析:

mysql執行計畫explain主要可以通過type來進行分析:

select_type 表示查詢中每個select子句的型別(簡單 or複雜)

a.******:查詢中不包含子查詢或者union

b.查詢中若包含任何複雜的子部分,最外層查詢則被標記為:primary

c.在select或where列表中包含了子查詢,該子查詢被標記為:subquery

d.在from列表中包含的子查詢被標記為:derived(衍生)

e.若第二個select出現在union之後,則被標記為union;若union包含在 from子句的子查詢中,外層select將被標記為:derived

f.從union表獲取結果的select被標記為:union result

type表示mysql在表中找到所需行的方式,又稱「訪問型別」,常見型別如下:(從上至下,效果依次變好)

all:full table scan。 index:full index scan。

range:索引範圍掃瞄。

ref :非唯一性索引掃瞄。

eq_ref :唯一性索引掃瞄。

const,system:將查詢轉換為乙個常量。

null:mysql在優化過程中分解語句,執行時甚至不用訪問表或索引

all :全表掃瞄,沒有用到索引

range:索引範圍掃瞄,對索引的掃瞄開始於某一點,返回匹配值域的行, 常見於between、,in等的查詢

ref: 非唯一性索引掃瞄,返回匹配某個單獨值的所有行。

eq_ref:唯一性索引掃瞄,對於每個索引鍵,表中只有一條記錄與之匹配。

const、system:當mysql對查詢某部分進行優化,並轉換為乙個常量時, 使用這些型別訪問。如將主鍵置於where列表中,mysql就能將該查詢轉 換為乙個常量。

system是const型別的特例,當查詢的表只有一行的情況下, 使用system。

null:mysql在優化過程中分解語句,執行時甚至不用訪問表或索引。

如:explain    select * from account_balance where    userid='123'

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表好呢,還是利用索引...