explain中怎么查看執(zhí)行計劃

explain中怎么查看執(zhí)行計劃,針對這個問題,這篇文章詳細介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

“只有客戶發(fā)展了,才有我們的生存與發(fā)展!”這是創(chuàng)新互聯(lián)的服務(wù)宗旨!把網(wǎng)站當(dāng)作互聯(lián)網(wǎng)產(chǎn)品,產(chǎn)品思維更注重全局思維、需求分析和迭代思維,在網(wǎng)站建設(shè)中就是為了建設(shè)一個不僅審美在線,而且實用性極高的網(wǎng)站。創(chuàng)新互聯(lián)對成都做網(wǎng)站、成都網(wǎng)站設(shè)計、網(wǎng)站制作、網(wǎng)站開發(fā)、網(wǎng)頁設(shè)計、網(wǎng)站優(yōu)化、網(wǎng)絡(luò)推廣、探索永無止境。

explain內(nèi)容

查看user全表查詢的執(zhí)行計劃:

MySQL> explain select * from user;

 explain中怎么查看執(zhí)行計劃

id

id表示select查詢語句的執(zhí)行順序或者是操作表的執(zhí)行順序。

id的值有二種情況:

  1. 鴻蒙官方戰(zhàn)略合作共建——HarmonyOS技術(shù)社區(qū)

  2. id相同,表示執(zhí)行的順序是由上至下

  3. id不同,id的序號會是遞增的,id的值越大表示優(yōu)先級越高,越先被執(zhí)行。

select_type

select_type表示查詢類型,它的值域為:SIMPLE、PRIMARY、SUBQUERY、DERIVED、UNION、UNION  RESULT。

  • SIMPLE:簡單的查詢,不包含子查詢和UNION。

  • PRIMARY:如果查詢的語句中包含了復(fù)雜的子查詢,那么最外層的查詢被標記為PRIMARY。

  • SUBQUERY:select或者where中的子查詢。

  • DERIVED:from列表中的子查詢生成的衍生表查詢。

  • UNION:聯(lián)合查詢。

  • UNION RESULT:從UNION表獲取結(jié)果的查詢。

table

數(shù)據(jù)行是從哪個表獲取的。

type

表示查詢使用了哪種類型,它的值域:ALL、index、range、ref、eq_ref、const、system。這是我們優(yōu)化時重點關(guān)注的一個指標。

從最好到最差排序:

system>const>eq_ref>ref>range>index>ALL。

阿里巴巴SQL優(yōu)化規(guī)范:

  • 【推薦】 SQL性能優(yōu)化的目標:至少要達到 range 級別,要求是ref級別,如果可以是const最好。

  • 說明:

  • 1)const 單表中最多只有一個匹配行(主鍵或者唯一索引),在優(yōu)化階段即可讀取到數(shù)據(jù)。

  • 2)ref 指的是使用普通的索引(normal index)。

  • 3)range 對索引進行范圍檢索。

system:表中只有一行記錄的查詢,類似系統(tǒng)表。

eq_ref:多表時唯一索引掃描,對于每一個索引,表中只有一行記錄相匹配。

index:索引物理文件全掃描,速度比較慢,比全表掃描性能好一點。

ALL:全表掃描。

possible_keys

可能應(yīng)用在這個表的索引,可以會一個或者多個,不一定是實際查詢使用的索引。

key

查詢中實際使用的索引,如果為null表示沒有使用索引。

如果是覆蓋索引,則只顯示在key中。

key_len

表示索引字段的最大可能長度,并不是實際的長度,它是根據(jù)表定義得到的,而不是通過表檢索得到的。長度越短越好。

ref

表示索引的哪一列被使用了,可能是個常數(shù)。哪些列或者常量被用于查找索引列上的值。

rows

根據(jù)表的信息和索引使用情況,大致估算的查找到所需的記錄需要掃描的行數(shù)。越小越好。

Extra

擴展信息。

阿里巴巴SQL優(yōu)化規(guī)范:

  • 【推薦】利用覆蓋索引來進行查詢操作,避免回表。

  • 說明:如果一本書需要知道第11章是什么標題,會翻開第11章對應(yīng)的那一頁嗎?目錄瀏覽一下就好,這個目錄就是起到覆蓋索引的作用。

  • 正例:能夠建立索引的種類分為主鍵索引、唯一索引、普通索引三種,而覆蓋索引只是一種查詢的一種效果,用explain的結(jié)果,extra列會出現(xiàn):using  index。

這里提到了覆蓋索引,extra列會出現(xiàn)using index。

extra還有其他比較重要的信息:

using filesort:用到了外部的索引排序,即MySQL無法利用索引完成排序。

using temptory:使用了臨時表。

using where:使用了where過濾。

關(guān)于explain中怎么查看執(zhí)行計劃問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。

當(dāng)前標題:explain中怎么查看執(zhí)行計劃
文章網(wǎng)址:http://bm7419.com/article28/ipohcp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、商城網(wǎng)站、App設(shè)計、微信小程序、網(wǎng)站改版、外貿(mào)網(wǎng)站建設(shè)

廣告

聲明:本網(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)

成都seo排名網(wǎng)站優(yōu)化