好程序員Java學習路線之MySQL的執行計劃

  好程序員Java學習路線之MySQL的執行計劃。什麼是執行計劃?執行計劃一般是開發者優化SQL語句的第一步。MySQL在解析SQL語句時,會生成多套執行方案,而後內部會進行一個成本的計算,而後經過優化器選擇一個最優的方案執行,而後根據這個方案會生成一個執行計劃。開發者經過查看SQL語句的執行計劃,能夠直觀的瞭解到MySQL是如何解析執行這條SQL語句的,而後再針對性的進行優化。mysql

 

如何查看SQL語句的執行計劃?程序員

        語法: explain  select語句;sql

 

執行計劃每一個字段的含義:性能

        

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

            id相同的狀況:  優化

            id不一樣的狀況:3d

            id相同不一樣同時存在:blog

            id爲null的狀況:排序

                比較少見,id爲null的部分必定是最後執行的索引

    

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

            

            mysql查詢的分類:

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

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

                                from後面有子查詢

                                包換union關鍵字

        

            SIMPLE:標識當前查詢是一個簡單查詢

                

 

            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和rows兩個字段來決定是否須要進行優化。

                好比type爲all,可是rows爲1,這種狀況下,其實徹底無需優化。       

                好比type爲ref, 可是rows爲10W,那麼這條sql語句性能確定比不上all - 1

 

        Extra(重要):表示當前一些額外的信息顯示的地方

            

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

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

            Using filesort:說明使用了文件排序,這個排序有可能在內存上排序,也有可能在硬盤上排序,若是是在硬盤上排序,則最好優化一下(好比經過索引進行排序)

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

相關文章
相關標籤/搜索