訂閱
糾錯(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ì)打印信息可通過上面圖的流程框架進(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é)束,也可以通過函數(shù)ExplainOnePlan看INSTR_TIME_SET_CURRENT(starttime);類似的時(shí)間。

聲明: 本文由入駐維科號(hào)的作者撰寫,觀點(diǎn)僅代表作者本人,不代表OFweek立場(chǎng)。如有侵權(quá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)論過于頻繁,請(qǐng)輸入驗(yàn)證碼繼續(xù)

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

暫無評(píng)論

暫無評(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)