欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Mysql中explain執(zhí)行計劃信息中字段

 更新時間:2023年08月31日 08:40:19   作者:*鄭*  
Extra是EXPLAIN輸出中另外一個很重要的列,該列顯示MySQL在查詢過程中的一些詳細信息,MySQL查詢優(yōu)化器執(zhí)行查詢的過程中對查詢計劃的重要補充信息,這篇文章主要介紹了Mysql中explain執(zhí)行計劃信息中字段詳解,需要的朋友可以參考下

Mysql中explain執(zhí)行計劃信息中字段詳解 

1. 獲取執(zhí)行計劃

explain select * from t5;
--或
desc select * from t5;

在這里插入圖片描述

2. 字段含義

2.1 id

每個select子句的執(zhí)行順序,相同從上到下,不同由大到小執(zhí)行

2.2 select_type

select語句類型

  • SIMPLE 簡單的select查詢,查詢中不包含子查詢或者UNION
  • PRIMARY 查詢中若包含任何復(fù)雜的子部分,最外層查詢則被標(biāo)記為PRIMARY
  • SUBQUERY 在SELECT或WHERE列表中包含了子查詢
  • DERIVED 在FROM列表中包含的子查詢被標(biāo)記為DERIVED(衍生),MySQL會遞歸執(zhí)行這些子查詢,把結(jié)果放在臨時表中
  • UNION 若第二個SELECT出現(xiàn)在UNION之后,則被標(biāo)記為UNION:若UNION包含在FROM子句的子查詢中,外層SELECT將被標(biāo)記為:DERIVED
  • UNION RESULT 從UNION表獲取結(jié)果的SELECT

2.3 table

當(dāng)前執(zhí)行的表名

2.4 partitions

顯示當(dāng)前訪問的分區(qū)

2.5 type

查詢使用了哪種類型

#由好到差依次是
system > const > eq_ref > ref > range > index > all
  • system 表只有一行記錄
  • const 表示通過索引一次找到,const用于比較primary key 或者unique索引
  • eq_ref 唯一性索引掃描,使用唯一性索引或主鍵查找時會發(fā)生
  • ref 索引掃描,它返回所有匹配某個單個值的行。此類索引訪問只有當(dāng)使用非唯一性索引或唯一性索引非唯一性前綴時才會發(fā)生
  • range 范圍掃描索,它返回所有匹配某個單個值的行。此類索引訪問只有當(dāng)使用非唯一性索引或唯一性索引非唯一性前綴時才會發(fā)生
  • index 和全表掃描一樣。只是掃描表的時候按照索引次序進行而不是行。主要優(yōu)點就是避免了排序, 但是開銷仍然非常大。如在Extra列看到Using index,說明正在使用覆蓋索引,只掃描索引的數(shù)據(jù),它比按索引次序全表掃描的開銷要小很多
  • all 全表掃描

2.6 possible_keys

顯示查詢使用了哪些索引,表示該索引可以進行高效地查找

2.7 key

key列顯示MySQL實際決定使用的鍵(索引)。如果沒有選擇索引,鍵是NULL。要想強制MySQL使用或忽視possible_keys列中的索引,在查詢中使用FORCE INDEX、USE INDEX或者IGNORE INDEX

2.8 ley_len

key_len列顯示MySQL決定使用的鍵長度。如果鍵是NULL,則長度為NULL。使用的索引的長度。在不損失精確性的情況下,長度越短越好

2.9 ref

顯示使用哪個列或常數(shù)與key一起從表中選擇行

2.10 rows

rows列顯示MySQL認(rèn)為它執(zhí)行查詢時必須檢查的行數(shù)。注意這是一個預(yù)估值

2.11 extra

Extra是EXPLAIN輸出中另外一個很重要的列,該列顯示MySQL在查詢過程中的一些詳細信息,MySQL查詢優(yōu)化器執(zhí)行查詢的過程中對查詢計劃的重要補充信息。

類型說明
Using filesortMySQL有兩種方式可以生成有序的結(jié)果,通過排序操作或者使用索引,當(dāng)Extra中出現(xiàn)了Using filesort 說明MySQL使用了后者,但注意雖然叫filesort但并不是說明就是用了文件來進行排序,只要可能排序都是在內(nèi)存里完成的。大部分情況下利用索引排序更快,所以一般這時也要考慮優(yōu)化查詢了。使用文件完成排序操作,這是可能是ordery by,group by語句的結(jié)果,這可能是一個CPU密集型的過程,可以通過選擇合適的索引來改進性能,用索引來為查詢結(jié)果排序。
Using temporary用臨時表保存中間結(jié)果,常用于GROUP BY 和 ORDER BY操作中,一般看到它說明查詢需要優(yōu)化了,就算避免不了臨時表的使用也要盡量避免硬盤臨時表的使用。
Not existsMYSQL優(yōu)化了LEFT JOIN,一旦它找到了匹配LEFT JOIN標(biāo)準(zhǔn)的行, 就不再搜索了。
Using index說明查詢是覆蓋了索引的,不需要讀取數(shù)據(jù)文件,從索引樹(索引文件)中即可獲得信息。如果同時出現(xiàn)using where,表明索引被用來執(zhí)行索引鍵值的查找,沒有using where,表明索引用來讀取數(shù)據(jù)而非執(zhí)行查找動作。這是MySQL服務(wù)層完成的,但無需再回表查詢記錄。
Using index condition這是MySQL 5.6出來的新特性,叫做“索引條件推送”。簡單說一點就是MySQL原來在索引上是不能執(zhí)行如like這樣的操作的,但是現(xiàn)在可以了,這樣減少了不必要的IO操作,但是只能用在二級索引上。
Using where使用了WHERE從句來限制哪些行將與下一張表匹配或者是返回給用戶。注意:Extra列出現(xiàn)Using where表示MySQL服務(wù)器將存儲引擎返回服務(wù)層以后再應(yīng)用WHERE條件過濾。
Using join buffer使用了連接緩存:Block Nested Loop,連接算法是塊嵌套循環(huán)連接;Batched Key Access,連接算法是批量索引連接
impossible wherewhere子句的值總是false,不能用來獲取任何元組
select tables optimized away在沒有GROUP BY子句的情況下,基于索引優(yōu)化MIN/MAX操作,或者對于MyISAM存儲引擎優(yōu)化COUNT(*)操作,不必等到執(zhí)行階段再進行計算,查詢執(zhí)行計劃生成的階段即完成優(yōu)化。
distinct優(yōu)化distinct操作,在找到第一匹配的元組后即停止找同樣值的動作

到此這篇關(guān)于Mysql中explain執(zhí)行計劃信息中字段詳解的文章就介紹到這了,更多相關(guān)Mysql explain執(zhí)行計劃內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql 操作數(shù)據(jù)庫基礎(chǔ)詳解

    mysql 操作數(shù)據(jù)庫基礎(chǔ)詳解

    這篇文章主要介紹了mysql 操作數(shù)據(jù)庫基礎(chǔ)詳解,MySQL是一種關(guān)系型數(shù)據(jù)庫管理系統(tǒng),關(guān)系數(shù)據(jù)庫將數(shù)據(jù)保存在不同的表中,而不是將所有數(shù)據(jù)放在一個大倉庫內(nèi),這樣就增加了速度并提高了靈活性
    2022-08-08
  • MySQL大表數(shù)據(jù)的分區(qū)與分庫分表的實現(xiàn)

    MySQL大表數(shù)據(jù)的分區(qū)與分庫分表的實現(xiàn)

    數(shù)據(jù)庫的分區(qū)和分庫分表是兩種常用的技術(shù)方案,本文主要介紹了MySQL大表數(shù)據(jù)的分區(qū)與分庫分表的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2025-03-03
  • mysql5.6 解析JSON字符串方式(支持復(fù)雜的嵌套格式)

    mysql5.6 解析JSON字符串方式(支持復(fù)雜的嵌套格式)

    這篇文章主要介紹了mysql5.6 解析JSON字符串方式(支持復(fù)雜的嵌套格式),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 查看MySQL的錯誤日志的方法

    查看MySQL的錯誤日志的方法

    我們經(jīng)常在運行MySQL時會出一些錯誤,也經(jīng)常被這些錯誤搞得暈頭轉(zhuǎn)向。當(dāng)然解決這些問題的首要任務(wù)是找到日志信息。
    2010-07-07
  • MYSQL日志與備份還原問題詳解

    MYSQL日志與備份還原問題詳解

    這篇文章主要為大家詳細介紹了MYSQL日志與備份還原問題,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • MySQL日期時間函數(shù)知識匯總

    MySQL日期時間函數(shù)知識匯總

    這篇文章主要介紹了MySQL日期時間函數(shù)知識匯總,這不同數(shù)據(jù)庫之間基本相同,只會有個別函數(shù)的差異。下文詳細介紹,需要的小伙伴可以參考一下
    2022-03-03
  • 一文解決連接MySQL報錯is?not?allowed?to?connect?to?this?MySQL?server

    一文解決連接MySQL報錯is?not?allowed?to?connect?to?this?MySQL?

    這篇文章主要給大家介紹了關(guān)于如何通過一文解決連接MySQL報錯is?not?allowed?to?connect?to?this?MySQL?server的相關(guān)資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-08-08
  • MySQL中SQL的執(zhí)行順序詳解

    MySQL中SQL的執(zhí)行順序詳解

    這篇文章主要介紹了MySQL中SQL的執(zhí)行順序,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-05-05
  • MySQL中利用索引對數(shù)據(jù)進行排序的基礎(chǔ)教程

    MySQL中利用索引對數(shù)據(jù)進行排序的基礎(chǔ)教程

    這篇文章主要介紹了MySQL中利用索引對數(shù)據(jù)進行排序的基礎(chǔ)教程,需要的朋友可以參考下
    2015-11-11
  • 講解Linux系統(tǒng)下如何自動備份MySQL數(shù)據(jù)的基本教程

    講解Linux系統(tǒng)下如何自動備份MySQL數(shù)據(jù)的基本教程

    這篇文章主要介紹了Linux系統(tǒng)下如何自動備份MySQL數(shù)據(jù)的基本教程,還給出了利用shell腳本全備份和增量備份的基本方法,需要的朋友可以參考下
    2015-11-11

最新評論