技術精講: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ù)調用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);類似的時間。
請輸入評論內容...
請輸入評論/評論長度6~500個字
最新活動更多
-
即日-10.29立即報名>> 2024德州儀器嵌入式技術創(chuàng)新發(fā)展研討會
-
10月31日立即下載>> 【限時免費下載】TE暖通空調系統(tǒng)高效可靠的組件解決方案
-
即日-11.13立即報名>>> 【在線會議】多物理場仿真助跑新能源汽車
-
11月14日立即報名>> 2024工程師系列—工業(yè)電子技術在線會議
-
12月19日立即報名>> 【線下會議】OFweek 2024(第九屆)物聯(lián)網產業(yè)大會
-
即日-12.26火熱報名中>> OFweek2024中國智造CIO在線峰會
推薦專題
- 高級軟件工程師 廣東省/深圳市
- 自動化高級工程師 廣東省/深圳市
- 光器件研發(fā)工程師 福建省/福州市
- 銷售總監(jiān)(光器件) 北京市/海淀區(qū)
- 激光器高級銷售經理 上海市/虹口區(qū)
- 光器件物理工程師 北京市/海淀區(qū)
- 激光研發(fā)工程師 北京市/昌平區(qū)
- 技術專家 廣東省/江門市
- 封裝工程師 北京市/海淀區(qū)
- 結構工程師 廣東省/深圳市