技術(shù)精講:PostgreSQL執(zhí)行計(jì)劃explain
入口函數(shù)為ExplainOnePlan,他會(huì)創(chuàng)建一個(gè)查詢描述結(jié)構(gòu)queryDesc,然后進(jìn)入執(zhí)行器執(zhí)行ExecutorStart、ExecutorRun、ExecutorFinish、ExecutorEnd。當(dāng)然執(zhí)行explain時(shí)可以添加analyze參數(shù),當(dāng)添加這個(gè)參數(shù)時(shí)才會(huì)執(zhí)行ExecutorRun即真正執(zhí)行該查詢。
打印執(zhí)行計(jì)劃是由函數(shù)ExplainPrintPlan完成,該函數(shù)調(diào)用ExplainNode,由入?yún)lanState結(jié)構(gòu)傳遞Plan tree。該P(yáng)lanState有initPlan(非相關(guān)子查詢)、lefttree、righttree、subPlan等。遍歷計(jì)劃樹就是對(duì)這幾個(gè)節(jié)點(diǎn)鏈進(jìn)行遞歸遍歷?梢钥吹,他打印完本節(jié)點(diǎn)信息后,若有左右子樹則遞歸進(jìn)行ExplainNode,然后對(duì)特殊節(jié)點(diǎn)進(jìn)行特殊處理,使用ExplainMemberNodes、ExplainNode和ExplainCustomChildren函數(shù)進(jìn)行處理。最后若有子計(jì)劃則遞歸遍歷subPlan。
詳細(xì)打印信息可通過上面圖的流程框架進(jìn)入每個(gè)函數(shù)深入閱讀理解。
GreenPlum的GPCC可以動(dòng)態(tài)以樹的形式打印執(zhí)行計(jì)劃,顯示執(zhí)行計(jì)劃執(zhí)行的進(jìn)度。理解explain如何打印執(zhí)行計(jì)劃及這些節(jié)點(diǎn)怎么遍歷后,可以更加方便理解推測GPCC打印執(zhí)行計(jì)劃的機(jī)制(因?yàn)間pcc還未開源)。
同時(shí)執(zhí)行計(jì)劃的執(zhí)行時(shí)間從什么時(shí)候開始,到什么時(shí)候結(jié)束,也可以通過函數(shù)ExplainOnePlan看INSTR_TIME_SET_CURRENT(starttime);類似的時(shí)間。

發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長度6~500個(gè)字
最新活動(dòng)更多
-
即日-9.16點(diǎn)擊進(jìn)入 >> 【限時(shí)福利】TE 2025國際物聯(lián)網(wǎng)展·深圳站
-
10月23日火熱報(bào)名中>> 2025是德科技創(chuàng)新技術(shù)峰會(huì)
-
10月23日立即報(bào)名>> Works With 開發(fā)者大會(huì)深圳站
-
10月24日立即參評(píng)>> 【評(píng)選】維科杯·OFweek 2025(第十屆)物聯(lián)網(wǎng)行業(yè)年度評(píng)選
-
11月27日立即報(bào)名>> 【工程師系列】汽車電子技術(shù)在線大會(huì)
-
12月18日立即報(bào)名>> 【線下會(huì)議】OFweek 2025(第十屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會(huì)
推薦專題
- 1 先進(jìn)算力新選擇 | 2025華為算力場景發(fā)布會(huì)暨北京xPN伙伴大會(huì)成功舉辦
- 2 人形機(jī)器人,正狂奔在批量交付的曠野
- 3 宇樹機(jī)器人撞人事件的深度剖析:六維力傳感器如何成為人機(jī)安全的關(guān)鍵屏障
- 4 解碼特斯拉新AI芯片戰(zhàn)略 :從Dojo到AI5和AI6推理引擎
- 5 AI版“四萬億刺激”計(jì)劃來了
- 6 騰訊 Q2 財(cái)報(bào)亮眼:AI 已成第二增長曲線
- 7 2025年8月人工智能投融資觀察
- 8 9 Manus跑路,大廠掉線,只能靠DeepSeek了
- 10 a16z最新AI百強(qiáng)榜:硅谷頂級(jí)VC帶你讀懂全球生成式AI賽道最新趨勢(shì)