訂閱
糾錯(cuò)
加入自媒體

技術(shù)精講:PostgreSQL執(zhí)行計(jì)劃explain

2021-05-10 09:21
yzsDBA
關(guān)注

入口函數(shù)為ExplainOnePlan,他會(huì)創(chuàng)建一個(gè)查詢描述結(jié)構(gòu)queryDesc,然后進(jìn)入執(zhí)行器執(zhí)行ExecutorStart、ExecutorRun、ExecutorFinish、ExecutorEnd。當(dāng)然執(zhí)行explain時(shí)可以添加analyze參數(shù),當(dāng)添加這個(gè)參數(shù)時(shí)才會(huì)執(zhí)行ExecutorRun即真正執(zhí)行該查詢。

打印執(zhí)行計(jì)劃是由函數(shù)ExplainPrintPlan完成,該函數(shù)調(diào)用ExplainNode,由入?yún)lanState結(jié)構(gòu)傳遞Plan tree。該P(yáng)lanState有initPlan(非相關(guān)子查詢)、lefttree、righttree、subPlan等。遍歷計(jì)劃樹就是對(duì)這幾個(gè)節(jié)點(diǎn)鏈進(jìn)行遞歸遍歷?梢钥吹,他打印完本節(jié)點(diǎn)信息后,若有左右子樹則遞歸進(jìn)行ExplainNode,然后對(duì)特殊節(jié)點(diǎn)進(jìn)行特殊處理,使用ExplainMemberNodes、ExplainNode和ExplainCustomChildren函數(shù)進(jìn)行處理。最后若有子計(jì)劃則遞歸遍歷subPlan。

詳細(xì)打印信息可通過(guò)上面圖的流程框架進(jìn)入每個(gè)函數(shù)深入閱讀理解。

GreenPlum的GPCC可以動(dòng)態(tài)以樹的形式打印執(zhí)行計(jì)劃,顯示執(zhí)行計(jì)劃執(zhí)行的進(jìn)度。理解explain如何打印執(zhí)行計(jì)劃及這些節(jié)點(diǎn)怎么遍歷后,可以更加方便理解推測(cè)GPCC打印執(zhí)行計(jì)劃的機(jī)制(因?yàn)間pcc還未開源)。

同時(shí)執(zhí)行計(jì)劃的執(zhí)行時(shí)間從什么時(shí)候開始,到什么時(shí)候結(jié)束,也可以通過(guò)函數(shù)ExplainOnePlan看INSTR_TIME_SET_CURRENT(starttime);類似的時(shí)間。

聲明: 本文由入駐維科號(hào)的作者撰寫,觀點(diǎn)僅代表作者本人,不代表OFweek立場(chǎng)。如有侵權(quán)或其他問(wèn)題,請(qǐng)聯(lián)系舉報(bào)。

發(fā)表評(píng)論

0條評(píng)論,0人參與

請(qǐng)輸入評(píng)論內(nèi)容...

請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字

您提交的評(píng)論過(guò)于頻繁,請(qǐng)輸入驗(yàn)證碼繼續(xù)

  • 看不清,點(diǎn)擊換一張  刷新

暫無(wú)評(píng)論

暫無(wú)評(píng)論

人工智能 獵頭職位 更多
掃碼關(guān)注公眾號(hào)
OFweek人工智能網(wǎng)
獲取更多精彩內(nèi)容
文章糾錯(cuò)
x
*文字標(biāo)題:
*糾錯(cuò)內(nèi)容:
聯(lián)系郵箱:
*驗(yàn) 證 碼:

粵公網(wǎng)安備 44030502002758號(hào)