内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

好程序員Java學(xué)習(xí)路線之MySQL的執(zhí)行計劃

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

成都創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比汕頭網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式汕頭網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋汕頭地區(qū)。費用合理售后完善,十多年實體公司更值得信賴。

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

執(zhí)行計劃每個字段的含義:

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

好程序員Java學(xué)習(xí)路線之MySQL的執(zhí)行計劃
id不同的情況:
好程序員Java學(xué)習(xí)路線之MySQL的執(zhí)行計劃
id相同不同同時存在:
好程序員Java學(xué)習(xí)路線之MySQL的執(zhí)行計劃
id為null的情況:
比較少見,id為null的部分一定是最后執(zhí)行的

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

        mysql查詢的分類:
            簡單查詢:沒有子查詢以及union的sql
            復(fù)雜查詢:where和select后面有子查詢
                            from后面有子查詢
                            包換union關(guān)鍵字

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

        PRIMARY:如果是一個復(fù)雜查詢(子查詢或者union),則最外層的SQL語句會被標記成這個類型
        SUBQUERY:用來標記一個子查詢(where、select)

            注意:通常來說被標記成PRIMARY的部分,是最后執(zhí)行的部分

        DERIVED:用來標記一個衍生查詢(from后面的子查詢)

        UNION:標記union關(guān)鍵字后面的查詢部分
        UNION RESULT:標記union結(jié)果的合并部分

    type(重要):用來標識當前這條SQL語句是用哪種方式訪問的數(shù)據(jù)行(最差 -> 最優(yōu))

        all:表示當前MySQL是采用全表掃描的方式訪問的數(shù)據(jù)行
        index:表示當前是按照全索引掃描的方式訪問所有數(shù)據(jù)行
        range:表示查詢了索引的某個范圍
        ref:表示查詢了索引的某個值,但是這個值是可能重復(fù)的(只會出現(xiàn)在非唯一性索引的字段上)
        eq_ref:表示查詢了索引的某個值,但是這個值是唯一的(只會出現(xiàn)在主鍵、唯一性索引上,并且需要結(jié)合連接查詢)
        const:查詢索引的某個唯一性值,mysql會將這個條件優(yōu)化成一個常量
        system(正式開發(fā)基本不會出現(xiàn)):表示mysql可以確定查詢的表結(jié)果一定只有一條
        null(性能最好,但是作用不大):表示當前SQL語句直接在解析時就能獲得結(jié)果,不能去查詢記錄行

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

    possible_keys :用來標記當前這條SQL語句可能用上的索引列表
    key(重要):用來標識當前這個SQL語句用上了哪個索引

        注意:有可能一個索引出現(xiàn)在possible_keys中,但是沒有出現(xiàn)在key中;也有可能一個索引出現(xiàn)在key中,但是沒有出現(xiàn)在possible_keys中。
        explain select * from student force index(idx_age) order by age;
        標識手動設(shè)置MySQL執(zhí)行的索引,但是最好不要這么干

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

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

        注意:通常在實際的優(yōu)化過程中,需要參考type和rows兩個字段來決定是否需要進行優(yōu)化。
            比如type為all,但是rows為1,這種情況下,其實完全無需優(yōu)化。       
            比如type為ref, 但是rows為10W,那么這條sql語句性能肯定比不上all - 1

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

        Using index:說明當前的執(zhí)行計劃用上了覆蓋索引。
        Using temporary:說明當前內(nèi)部使用了臨時表(分組、排序)
        Using filesort:說明使用了文件排序,這個排序有可能在內(nèi)存上排序,也有可能在硬盤上排序,如果是在硬盤上排序,則最好優(yōu)化一下(比如通過索引進行排序)
        Using where:表示使用了過濾條件

網(wǎng)站標題:好程序員Java學(xué)習(xí)路線之MySQL的執(zhí)行計劃
當前路徑:http://www.rwnh.cn/article4/ihjdie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站策劃、微信公眾號、電子商務(wù)、云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設(shè)計
确山县| 武鸣县| 辽中县| 益阳市| 临夏县| 黄骅市| 金坛市| 榆树市| 鹤岗市| 郴州市| 澄城县| 朝阳县| 临桂县| 永寿县| 灵宝市| 独山县| 门源| 页游| 虎林市| 东乡县| 永新县| 镇康县| 新宾| 唐海县| 崇礼县| 天台县| 巩义市| 海阳市| 平和县| 麦盖提县| 松江区| 宽城| 邢台市| 新晃| 天门市| 岗巴县| 汾阳市| 永昌县| 兴国县| 甘肃省| 莎车县|