成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

聊聊explain查看執行計劃

數據庫 MySQL
在MySQL性能調優的時候explain是必須要使用的關鍵字,它的作用是可以查看sql語句的執行信息,包括表的讀取順序,應用到的索引等信息。

[[388066]]

 在MySQL性能調優的時候explain是必須要使用的關鍵字,它的作用是可以查看sql語句的執行信息,包括表的讀取順序,應用到的索引等信息。

用法:explain + sql語句。

本篇我們先熟悉explain的內容,為下篇學習索引奠定基礎。

explain內容

查看user全表查詢的執行計劃:

  1. mysql> explain select * from user

 

id

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

id的值有二種情況:

  1. id相同,表示執行的順序是由上至下
  2. id不同,id的序號會是遞增的,id的值越大表示優先級越高,越先被執行。

select_type

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

  • SIMPLE:簡單的查詢,不包含子查詢和UNION。
  • PRIMARY:如果查詢的語句中包含了復雜的子查詢,那么最外層的查詢被標記為PRIMARY。
  • SUBQUERY:select或者where中的子查詢。
  • DERIVED:from列表中的子查詢生成的衍生表查詢。
  • UNION:聯合查詢。
  • UNION RESULT:從UNION表獲取結果的查詢。

table

數據行是從哪個表獲取的。

type

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

從最好到最差排序:

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

阿里巴巴SQL優化規范:

  • 【推薦】 SQL性能優化的目標:至少要達到 range 級別,要求是ref級別,如果可以是const最好。
  • 說明:
  • 1)const 單表中最多只有一個匹配行(主鍵或者唯一索引),在優化階段即可讀取到數據。
  • 2)ref 指的是使用普通的索引(normal index)。
  • 3)range 對索引進行范圍檢索。

system:表中只有一行記錄的查詢,類似系統表。

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

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

ALL:全表掃描。

possible_keys

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

key

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

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

key_len

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

ref

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

rows

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

Extra

擴展信息。

阿里巴巴SQL優化規范:

  • 【推薦】利用覆蓋索引來進行查詢操作,避免回表。
  • 說明:如果一本書需要知道第11章是什么標題,會翻開第11章對應的那一頁嗎?目錄瀏覽一下就好,這個目錄就是起到覆蓋索引的作用。
  • 正例:能夠建立索引的種類分為主鍵索引、唯一索引、普通索引三種,而覆蓋索引只是一種查詢的一種效果,用explain的結果,extra列會出現:using index。

這里提到了覆蓋索引,extra列會出現using index。

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

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

using temptory:使用了臨時表。

using where:使用了where過濾。

還有其他幾種,不是經常出現,我們就不說明了。

 

責任編輯:姜華 來源: 今日頭條
相關推薦

2023-09-21 10:55:51

MysqlSQL語句

2024-09-12 15:16:14

2021-02-20 08:40:19

HiveExplain底層

2022-02-15 07:36:21

SQLEXPLAIN數據庫

2011-09-14 17:03:17

數據庫執行計劃解析

2020-05-21 10:02:51

Explain SQL優化

2025-03-12 10:55:30

2025-01-24 14:57:24

2015-04-22 14:17:45

SQL SERVERMSSQL SERVE緩沖區

2021-05-28 10:46:36

MySQL執行計劃

2009-11-13 16:28:02

Oracle生成執行計

2022-08-08 08:03:44

MySQL數據庫CBO

2022-08-15 15:09:26

SQL數據庫MySQL

2010-04-16 09:27:18

Ocacle執行計劃

2009-11-10 16:00:05

Oracle執行計劃

2021-09-07 10:43:25

EverDB分布式執行

2020-09-15 08:44:57

MySQL慢日志SQL

2021-04-24 12:01:08

MySQL數據庫Mysql執行計劃

2009-11-18 17:05:47

捕獲Oracle SQ

2022-12-13 08:36:42

D-SMARTOracle數據庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产福利91精品一区二区三区 | 国产在线小视频 | 夜夜草 | 久久久久久电影 | 国产精品无码久久久久 | 成人午夜高清 | 亚洲国产精品久久久 | 午夜视频在线免费观看 | 久久夜视频 | 成人乱人乱一区二区三区软件 | 91精品国产综合久久福利软件 | 91九色视频 | www.色婷婷 | 妹子干综合 | 草草视频在线播放 | 五月天天丁香婷婷在线中 | 一区二区精品 | 精品乱码一区二区 | 国产精品视频久久 | 成人午夜影院 | 久久er99热精品一区二区 | 亚洲天堂精品一区 | 91网在线观看| 欧美精品乱码久久久久久按摩 | 国产一区二区a | 国产精品毛片一区二区三区 | 亚洲国产网 | 欧美日韩在线电影 | 亚洲综合区 | 天天综合成人网 | 亚洲欧美一区二区三区在线 | 日韩在线看片 | 99免费 | 一级做受毛片免费大片 | av免费入口 | 高清成人免费视频 | 亚洲美女在线视频 | 6996成人影院网在线播放 | h视频免费在线观看 | 91天堂| 成人在线免费观看 |