技術(shù)精講:PostgreSQL執(zhí)行計劃explain
入口函數(shù)為ExplainOnePlan,他會創(chuàng)建一個查詢描述結(jié)構(gòu)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結(jié)構(gòu)傳遞Plan tree。該PlanState有initPlan(非相關(guān)子查詢)、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í)行時間從什么時候開始,到什么時候結(jié)束,也可以通過函數(shù)ExplainOnePlan看INSTR_TIME_SET_CURRENT(starttime);類似的時間。

最新活動更多
推薦專題
- 1 先進算力新選擇 | 2025華為算力場景發(fā)布會暨北京xPN伙伴大會成功舉辦
- 2 人形機器人,正狂奔在批量交付的曠野
- 3 宇樹機器人撞人事件的深度剖析:六維力傳感器如何成為人機安全的關(guān)鍵屏障
- 4 解碼特斯拉新AI芯片戰(zhàn)略 :從Dojo到AI5和AI6推理引擎
- 5 AI版“四萬億刺激”計劃來了
- 6 2025年8月人工智能投融資觀察
- 7 特斯拉三代靈巧手:演進歷程與核心供應(yīng)鏈梳理
- 8 a16z最新AI百強榜:硅谷頂級VC帶你讀懂全球生成式AI賽道最新趨勢
- 9 Manus跑路,大廠掉線,只能靠DeepSeek了
- 10 地平線的野心:1000萬套HSD上車