Explain Analyze在MySQL 8.0.18版本中的擴展使用

在以前的版本里,咱們是用explain命令來查看SQL的具體執行計劃。在MySQL 8.0.18版本里新增了explain擴展,一個是explain format=tree,另外一個是基於explain format=tree延伸擴展的Explain Analyze,今天咱們查看下該命令是怎樣執行的。bash


仍是用sbtest1表作測試。ide

explain analyze select count(*) from sbtest1;

1.png

這個結果很讓人奇怪,不加where條件,啥都不能顯示出來,貌似是個BUG?測試


得,加個where id>0再試試。spa

explain analyze select count(*) from sbtest1 where id>0;

2.png

注意看紅色劃線部分,它內部會運行查詢並測量執行時間。orm


含義解釋:blog

1) cost部分的rows=4936262,是和explain生成的結果一致,都是估算讀取的行數。ci

3.png


2)actual部分的rows=10000000,是執行這條SQL返回的真正結果,見以下圖所示it

4.png


3)actual time=62004.565(單位ms毫秒),轉換爲秒是這條SQL執行的時間爲62秒,但實際上是有很大的偏差的,你看上面的io

執行時間7.98秒,就四捨五入爲8秒,62/8大約偏差達到了77%左右,所以咱們不能真正相信這些數字。form

相關文章
相關標籤/搜索