真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

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

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

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

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

    id(重要):主要用來(lái)標(biāo)識(shí)SQL語(yǔ)句的解析執(zhí)行順序
        id相同的情況:  

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

    select_type:主要用來(lái)標(biāo)識(shí)當(dāng)前查詢(xún)的類(lèi)型

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

        SIMPLE:標(biāo)識(shí)當(dāng)前查詢(xún)是一個(gè)簡(jiǎn)單查詢(xún)

        PRIMARY:如果是一個(gè)復(fù)雜查詢(xún)(子查詢(xún)或者union),則最外層的SQL語(yǔ)句會(huì)被標(biāo)記成這個(gè)類(lèi)型
        SUBQUERY:用來(lái)標(biāo)記一個(gè)子查詢(xún)(where、select)

            注意:通常來(lái)說(shuō)被標(biāo)記成PRIMARY的部分,是最后執(zhí)行的部分

        DERIVED:用來(lái)標(biāo)記一個(gè)衍生查詢(xún)(from后面的子查詢(xún))

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

    type(重要):用來(lái)標(biāo)識(shí)當(dāng)前這條SQL語(yǔ)句是用哪種方式訪(fǎng)問(wèn)的數(shù)據(jù)行(最差 -> 最優(yōu))

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

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

    possible_keys :用來(lái)標(biāo)記當(dāng)前這條SQL語(yǔ)句可能用上的索引列表
    key(重要):用來(lái)標(biāo)識(shí)當(dāng)前這個(gè)SQL語(yǔ)句用上了哪個(gè)索引

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

    key_len:標(biāo)識(shí)當(dāng)前使用到的索引長(zhǎng)度,這個(gè)值越大,說(shuō)明越多的條件使用上了索引

    rows(重要):表示當(dāng)前查詢(xún)可能訪(fǎng)問(wèn)的記錄行數(shù),這個(gè)值越小越好,最好顯示1

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

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

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

本文名稱(chēng):好程序員Java學(xué)習(xí)路線(xiàn)之MySQL的執(zhí)行計(jì)劃
標(biāo)題路徑:http://weahome.cn/article/ihjdie.html

其他資訊

在線(xiàn)咨詢(xún)

微信咨詢(xún)

電話(huà)咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部