mysql 生成執行計畫 MySQL的執行計畫

2021-10-18 10:20:36 字數 2004 閱讀 5620

mysql的執行計畫

什麼是執行計畫?

執行計畫通常是開發者優化sql語句的第一步。mysql在解析sql語句時,會生成多套執行方案,然後內部會進行乙個成本的計算,然後通過優化器選擇乙個最優的方案執行,然後根據這個方案會生成乙個執行計畫。開發者通過檢視sql語句的執行計畫,可以直觀的了解到mysql是如何解析執行這條sql語句的,然後再針對性的進行優化。

如何檢視sql語句的執行計畫?

語法: explain select語句;

執行計畫每個欄位的含義:

id(重要):主要用來標識sql語句的解析執行順序

id相同的情況:

id不同的情況:

id相同不同同時存在:

id為null的情況:

比較少見,id為null的部分一定是最後執行的

select_type:主要用來標識當前查詢的型別

mysql查詢的分類:

簡單查詢:沒有子查詢以及union的sql

複雜查詢:where和select後面有子查詢

from後面有子查詢

包換union關鍵字

******:標識當前查詢是乙個簡單查詢

primary:如果是乙個複雜查詢(子查詢或者union),則最外層的sql語句會被標記成這個型別

subquery:用來標記乙個子查詢(where、select)

注意:通常來說被標記成primary的部分,是最後執行的部分

derived:用來標記乙個衍生查詢(from後面的子查詢)

union:標記union關鍵字後面的查詢部分

union result:標記union結果的合併部分

type(重要):用來標識當前這條sql語句是用哪種方式訪問的資料行(最差 -> 最優)

all:表示當前mysql是採用全表掃瞄的方式訪問的資料行

index:表示當前是按照全索引掃瞄的方式訪問所有資料行

range:表示查詢了索引的某個範圍

ref:表示查詢了索引的某個值,但是這個值是可能重複的(只會出現在非唯一性索引的字段上)

eq_ref:表示查詢了索引的某個值,但是這個值是唯一的(只會出現在主鍵、唯一性索引上,並且需要結合連線查詢)

const:查詢索引的某個唯一性值,mysql會將這個條件優化成乙個常量

system(正式開發基本不會出現):表示mysql可以確定查詢的表結果一定只有一條

null(效能最好,但是作用不大):表示當前sql語句直接在解析時就能獲得結果,不能去查詢記錄行

注意:通常在實際開發過程中,需要將sql語句優化到range以上的級別,但是一定要具體問題具體分析,有些時候all反而是更好的行為。

possible_keys :用來標記當前這條sql語句可能用上的索引列表

key(重要):用來標識當前這個sql語句用上了哪個索引

注意:有可能乙個索引出現在possible_keys中,但是沒有出現在key中;也有可能乙個索引出現在key中,但是沒有出現在possible_keys中。

explain select * from student force index(idx_age) order by age;

標識手動設定mysql執行的索引,但是最好不要這麼幹

key_len:標識當前使用到的索引長度,這個值越大,說明越多的條件使用上了索引

rows(重要):表示當前查詢可能訪問的記錄行數,這個值越小越好,最好顯示1

比如type為all,但是rows為1,這種情況下,其實完全無需優化。

比如type為ref, 但是rows為10w,那麼這條sql語句效能肯定比不上all - 1

extra(重要):表示當前一些額外的資訊顯示的地方

using index:說明當前的執行計畫用上了覆蓋索引。

using temporary:說明當前內部使用了臨時表(分組、排序)

using filesort:說明使用了檔案排序,這個排序有可能在記憶體上排序,也有可能在硬碟上排序,如果是在硬碟上排序,則最好優化一下(比如通過索引進行排序)

using where:表示使用了過濾條件

mysql 生成執行計畫 MySQL執行計畫

和很多其他關係型資料庫不通,mysql並不會在生成查詢位元組碼來執行查詢。mysql生成查詢的一棵指令樹,然後通過儲存引擎執行完成這棵指令樹並返回結果。最終的執行計畫包含了重構查詢的全部資訊。如果某個查詢執行explain extended 之後,在執行show warnings,就可以看到重構出的...

mysql執行計畫 MySQL 執行計畫

1.執行計畫的定義 什麼是執行計畫 查詢計畫 呢?執行計畫就是一系列的操作步驟。sql是宣告性語言,它只告訴資料庫要查詢什麼,但並不告訴資料庫如何去查。資料庫所要做的就是基於演算法和統計資訊計算出一條最佳的訪問路徑。這個工作是由優化器來完成的。優化器會比較不同的執行計畫,然後選擇其中最優的一套。2....

mysql 查詢執行計畫 MySql執行計畫的檢視

一。什麼是資料庫執行計畫 利用乙個sql語句,你可能要server取出所有news表中的資訊.當server收到的這條sql的時候,第一件事情並不是解析它.如果這條sql沒有語法錯誤,server才會繼續工作.server會決定最好的計算方式.server會選擇,是讀整個news表好呢,還是利用索引...