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