技術精講:PostgreSQL執行計劃explain

入口函數為ExplainOnePlan,他會創建一個查詢描述結構queryDesc,然后進入執行器執行ExecutorStart、ExecutorRun、ExecutorFinish、ExecutorEnd。當然執行explain時可以添加analyze參數,當添加這個參數時才會執行ExecutorRun即真正執行該查詢。
打印執行計劃是由函數ExplainPrintPlan完成,該函數調用ExplainNode,由入參PlanState結構傳遞Plan tree。該PlanState有initPlan(非相關子查詢)、lefttree、righttree、subPlan等。遍歷計劃樹就是對這幾個節點鏈進行遞歸遍歷。可以看到,他打印完本節點信息后,若有左右子樹則遞歸進行ExplainNode,然后對特殊節點進行特殊處理,使用ExplainMemberNodes、ExplainNode和ExplainCustomChildren函數進行處理。最后若有子計劃則遞歸遍歷subPlan。
詳細打印信息可通過上面圖的流程框架進入每個函數深入閱讀理解。
GreenPlum的GPCC可以動態以樹的形式打印執行計劃,顯示執行計劃執行的進度。理解explain如何打印執行計劃及這些節點怎么遍歷后,可以更加方便理解推測GPCC打印執行計劃的機制(因為gpcc還未開源)。
同時執行計劃的執行時間從什么時候開始,到什么時候結束,也可以通過函數ExplainOnePlan看INSTR_TIME_SET_CURRENT(starttime);類似的時間。
請輸入評論內容...
請輸入評論/評論長度6~500個字
最新活動更多
- 1 AI狂歡遇上油價破百,全球股市還能漲多久? | 產聯看全球
- 2 OpenAI深夜王炸!ChatGPT Images 2.0實測:中文穩、細節炸,設計師慌了
- 3 6000億美元估值錨定:字節跳動的“去單一化”突圍與估值重構
- 4 Tesla AI5芯片最新進展總結
- 5 連夜測了一波DeepSeek-V4,我發現它可能只剩“審美”這個短板了
- 6 熱點丨AI“瑜亮之爭”:既生OpenClaw,何生Hermes?
- 7 AI界的殺豬盤:9秒刪庫跑路,全員被封號,還繼續扣錢!
- 8 2026,人形機器人只贏了面子
- 9 DeepSeek降價90%:價格屠夫不是身份,是戰略
- 10 AI Infra產業鏈卡在哪里了?


分享













