訂閱
糾錯
加入自媒體

技術精講:PostgreSQL執(zhí)行計劃explain

2021-05-10 09:21
yzsDBA
關注

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

打印執(zhí)行計劃是由函數(shù)ExplainPrintPlan完成,該函數(shù)調用ExplainNode,由入參PlanState結構傳遞Plan tree。該PlanState有initPlan(非相關子查詢)、lefttree、righttree、subPlan等。遍歷計劃樹就是對這幾個節(jié)點鏈進行遞歸遍歷。可以看到,他打印完本節(jié)點信息后,若有左右子樹則遞歸進行ExplainNode,然后對特殊節(jié)點進行特殊處理,使用ExplainMemberNodes、ExplainNode和ExplainCustomChildren函數(shù)進行處理。最后若有子計劃則遞歸遍歷subPlan。

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

GreenPlum的GPCC可以動態(tài)以樹的形式打印執(zhí)行計劃,顯示執(zhí)行計劃執(zhí)行的進度。理解explain如何打印執(zhí)行計劃及這些節(jié)點怎么遍歷后,可以更加方便理解推測GPCC打印執(zhí)行計劃的機制(因為gpcc還未開源)。

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

聲明: 本文由入駐維科號的作者撰寫,觀點僅代表作者本人,不代表OFweek立場。如有侵權或其他問題,請聯(lián)系舉報。

發(fā)表評論

0條評論,0人參與

請輸入評論內容...

請輸入評論/評論長度6~500個字

您提交的評論過于頻繁,請輸入驗證碼繼續(xù)

暫無評論

暫無評論

人工智能 獵頭職位 更多
掃碼關注公眾號
OFweek人工智能網
獲取更多精彩內容
文章糾錯
x
*文字標題:
*糾錯內容:
聯(lián)系郵箱:
*驗 證 碼:

粵公網安備 44030502002758號