技術精講:PostgreSQL執(zhí)行計劃explain
入口函數(shù)為ExplainOnePlan,他會創(chuàng)建一個查詢描述結構queryDesc,然后進入執(zhí)行器執(zhí)行ExecutorStart、ExecutorRun、ExecutorFinish、ExecutorEnd。當然執(zhí)行explain時可以添加analyze參數(shù),當添加這個參數(shù)時才會執(zhí)行ExecutorRun即真正執(zhí)行該查詢。
打印執(zhí)行計劃是由函數(shù)ExplainPrintPlan完成,該函數(shù)調(diào)用ExplainNode,由入?yún)lanState結構傳遞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);類似的時間。

請輸入評論內(nèi)容...
請輸入評論/評論長度6~500個字
最新活動更多
-
10 大模型的盡頭是開源
- 1 特斯拉工人被故障機器人打成重傷,索賠3.6億
- 2 【行業(yè)深度研究】退居幕后四年后,張一鳴終于把算法公司變成AI公司?
- 3 人形機器人廠商,正在批量復刻宇樹G1
- 4 AI 時代,阿里云想當“安卓” ,那誰是“蘋果”?
- 5 華為公布昇騰芯片三年計劃,自研HBM曝光
- 6 硬剛英偉達!華為發(fā)布全球最強算力超節(jié)點和集群
- 7 機器人9月大事件|3家國產(chǎn)機器人沖刺IPO,行業(yè)交付與融資再創(chuàng)新高!
- 8 谷歌“香蕉”爆火啟示:國產(chǎn)垂類AI的危機還是轉機?
- 9 00后華裔女生靠兩部AI電影狂賺7.8億人民幣,AI正式進軍好萊塢
- 10 美光:AI Capex瘋投不止,終于要拉起存儲超級周期了?