您好,登錄后才能下訂單哦!
在之前的版本里,我們是用explain命令來查看SQL的具體執行計劃。在MySQL 8.0.18版本里新增了explain擴展,一個是explain format=tree,另一個是基于explain format=tree延伸擴展的Explain Analyze,今天我們查看下該命令是怎樣執行的。
還是用sbtest1表做測試。
explain?analyze?select?count(*)?from?sbtest1;
這個結果很讓人奇怪,不加where條件,啥都不能顯示出來,貌似是個BUG?
得,加個where id>0再試試。
explain?analyze?select?count(*)?from?sbtest1?where?id>0;
注意看紅色劃線部分,它內部會運行查詢并測量執行時間。
含義解釋:
1) cost部分的rows=4936262,是和explain生成的結果一致,都是估算讀取的行數。
2)actual部分的rows=10000000,是執行這條SQL返回的真正結果,見如下圖所示
3)actual time=62004.565(單位ms毫秒),轉換為秒是這條SQL執行的時間為62秒,但其實是有很大的誤差的,你看上面的
執行時間7.98秒,就四舍五入為8秒,62/8大約誤差達到了77%左右,因此我們不能真正相信這些數字。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。