在以前的版本里,咱們是用explain命令來查看SQL的具體執行計劃。在MySQL 8.0.18版本里新增了explain擴展,一個是explain format=tree,另外一個是基於explain format=tree延伸擴展的Explain Analyze,今天咱們查看下該命令是怎樣執行的。bash
仍是用sbtest1表作測試。ide
explain analyze select count(*) from sbtest1;
這個結果很讓人奇怪,不加where條件,啥都不能顯示出來,貌似是個BUG?測試
得,加個where id>0再試試。spa
explain analyze select count(*) from sbtest1 where id>0;
注意看紅色劃線部分,它內部會運行查詢並測量執行時間。orm
含義解釋:blog
1) cost部分的rows=4936262,是和explain生成的結果一致,都是估算讀取的行數。ci
2)actual部分的rows=10000000,是執行這條SQL返回的真正結果,見以下圖所示it
3)actual time=62004.565(單位ms毫秒),轉換爲秒是這條SQL執行的時間爲62秒,但實際上是有很大的偏差的,你看上面的io
執行時間7.98秒,就四捨五入爲8秒,62/8大約偏差達到了77%左右,所以咱們不能真正相信這些數字。form