中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-06-26 20:41:03 來源:網絡 閱讀:187 作者:wx5d42865f47214 欄目:編程語言

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

如何查看SQL語句的執行計劃?
語法: explain select語句;

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

    id(重要):主要用來標識SQL語句的解析執行順序
        id相同的情況:  

好程序員Java學習路線之MySQL的執行計劃
id不同的情況:
好程序員Java學習路線之MySQL的執行計劃
id相同不同同時存在:
好程序員Java學習路線之MySQL的執行計劃
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:表示使用了過濾條件
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

务川| 南康市| 九龙坡区| 威宁| 湖口县| 西和县| 大化| 木里| 浮梁县| 叶城县| 翁源县| 长垣县| 苏尼特左旗| 锡林浩特市| 宾川县| 桐乡市| 南丹县| 康平县| 禹城市| 周至县| 土默特左旗| 汉源县| 乌鲁木齐市| 佛山市| 武夷山市| 菏泽市| 无为县| 淮阳县| 西林县| 东源县| 高密市| 南涧| 荣昌县| 宁都县| 天津市| 漾濞| 延安市| 洛宁县| 滁州市| 且末县| 会同县|