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

發(fā)表評論
請輸入評論內(nèi)容...
請輸入評論/評論長度6~500個字
最新活動更多
-
7月8日立即報名>> 【在線會議】英飛凌新一代智能照明方案賦能綠色建筑與工業(yè)互聯(lián)
-
7月22-29日立即報名>> 【線下論壇】第三屆安富利汽車生態(tài)圈峰會
-
7月31日免費(fèi)預(yù)約>> OFweek 2025具身機(jī)器人動力電池技術(shù)應(yīng)用大會
-
7.30-8.1火熱報名中>> 全數(shù)會2025(第六屆)機(jī)器人及智能工廠展
-
免費(fèi)參會立即報名>> 7月30日- 8月1日 2025全數(shù)會工業(yè)芯片與傳感儀表展
-
即日-2025.8.1立即下載>> 《2024智能制造產(chǎn)業(yè)高端化、智能化、綠色化發(fā)展藍(lán)皮書》
推薦專題
- 1 AI 眼鏡讓百萬 APP「集體失業(yè)」?
- 2 豆包前負(fù)責(zé)人喬木出軌BP后續(xù):均被辭退
- 3 一文看懂視覺語言動作模型(VLA)及其應(yīng)用
- 4 “支付+”時代,支付即生態(tài) | 2025中國跨境支付十大趨勢
- 5 中國最具實(shí)力AI公司TOP10
- 6 特斯拉Robotaxi上路,馬斯克端上畫了十年的餅
- 7 國家數(shù)據(jù)局局長劉烈宏調(diào)研格創(chuàng)東智
- 8 AI的夏天:第四范式VS云從科技VS地平線機(jī)器人
- 9 張勇等人退出阿里合伙人
- 10 深圳跑出40億超級隱形冠軍:賣機(jī)器人年入6.1億,港股上市