溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Explain Analyze在MySQL 8.0.18版本

發(fā)布時間:2020-02-29 20:21:04 來源:網(wǎng)絡(luò) 閱讀:639 作者:hcymysql 欄目:MySQL數(shù)據(jù)庫

在之前的版本里,我們是用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;

Explain Analyze在MySQL 8.0.18版本

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


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

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

Explain Analyze在MySQL 8.0.18版本

注意看紅色劃線部分,它內(nèi)部會運行查詢并測量執(zhí)行時間。


含義解釋:

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

Explain Analyze在MySQL 8.0.18版本


2)actual部分的rows=10000000,是執(zhí)行這條SQL返回的真正結(jié)果,見如下圖所示

Explain Analyze在MySQL 8.0.18版本


3)actual time=62004.565(單位ms毫秒),轉(zhuǎn)換為秒是這條SQL執(zhí)行的時間為62秒,但其實是有很大的誤差的,你看上面的

執(zhí)行時間7.98秒,就四舍五入為8秒,62/8大約誤差達(dá)到了77%左右,因此我們不能真正相信這些數(shù)字。



向AI問一下細(xì)節(jié)

免責(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)容。

AI