時(shí)光荏苒,歲月如梭。樓主已經(jīng)很久沒(méi)有更新了。之前說(shuō)好的一周一更的沒(méi)有做到。實(shí)在是事出有因,沒(méi)能靜下心來(lái)好好看代碼。當(dāng)然這不能作為我不更新的理由,時(shí)間擠擠還是有的,拖了這么久,該再寫(xiě)點(diǎn)東西了,不然人就怠懶了。不過(guò)這回,我準(zhǔn)備寫(xiě)的精簡(jiǎn)些,一方面我想偷點(diǎn)懶省點(diǎn)時(shí)間,二來(lái)畢竟寫(xiě)太長(zhǎng)大家也不一定愛(ài)看。
之前我說(shuō)過(guò)的查詢分析,查詢重寫(xiě)和查詢規(guī)劃都是相當(dāng)于是對(duì)查詢的"編譯"。那么編譯完了就應(yīng)該按照既定的策略去執(zhí)行它。本篇就來(lái)介紹查詢執(zhí)行模塊的代碼(Executor),歡迎拍磚。
這部分我主要從以下五個(gè)部分介紹查詢執(zhí)行模塊(很可能要分成四到五篇文章來(lái)闡述,畢竟是比查詢規(guī)劃還要復(fù)雜的模塊):
1.查詢優(yōu)化策略 2.非可優(yōu)化語(yǔ)句的執(zhí)行 3.可優(yōu)化語(yǔ)句的執(zhí)行 4.計(jì)劃節(jié)點(diǎn) 5.其它子功能介紹
查詢執(zhí)行器的框架結(jié)構(gòu)如下圖所示。
在exec_simple_query函數(shù)中,調(diào)用查詢編譯模塊之后,就進(jìn)入了查詢執(zhí)行器模塊。在該模塊中,就是按照前一階段查詢規(guī)劃模塊鎖生成的查詢計(jì)劃,有機(jī)第調(diào)用存儲(chǔ)、索引,并發(fā)等模塊來(lái)完成數(shù)據(jù)的讀取或者修改的過(guò)程。
在本模塊中,總共下屬四個(gè)子模塊,分別是:Portal、ProcessUtility、Executor和其他特定子功能模塊。
我們知道,查詢規(guī)劃階段將查詢分為兩種類(lèi)型,在查詢執(zhí)行模塊中,先由Portal模塊識(shí)別查詢類(lèi)型(有計(jì)劃樹(shù)和無(wú)計(jì)劃樹(shù)),根據(jù)查詢類(lèi)型分別指派Executor模塊和ProcessUtility模塊進(jìn)行處理。
這兩個(gè)子模塊的處理邏輯相差很大,執(zhí)行過(guò)程和先關(guān)數(shù)據(jù)結(jié)構(gòu)差異也很大。
對(duì)于Executor模塊,它根據(jù)輸入的查詢計(jì)劃樹(shù)按部就班地處理數(shù)據(jù)表中元組的增刪改查(DML)操作,它的執(zhí)行邏輯是統(tǒng)一的(所有的增刪改查最后都?xì)w結(jié)為SELECT,只是分別在SELECT的基礎(chǔ)上進(jìn)行一些額外的操作)。其主要代碼放在src/backend/executor下。
而對(duì)于ProcessUtility模塊,由于處理的是除了增刪改查之外的所有其他操作,而這些操作往往差異很大,例如數(shù)據(jù)定義操作(DDL),事務(wù)的處理以及游標(biāo)用戶角色定義這些,因此在ProcessUtility模塊中,為每種操作單獨(dú)地設(shè)計(jì)了子過(guò)程(函數(shù))去處理。主要代碼在src/backend/commands下。
而剩下的我說(shuō)的特定功能子模塊,是指一些功能相對(duì)獨(dú)立和單一并且在整個(gè)查詢過(guò)程中會(huì)反復(fù)被調(diào)用的函數(shù)(我更愿意稱他們?yōu)楣ぞ吆瘮?shù)),例如各種輔助的子系統(tǒng),表達(dá)式的計(jì)算,投影運(yùn)算以及元組操作這些。
1.查詢優(yōu)化策略
在進(jìn)入這一模塊之前,我已經(jīng)簡(jiǎn)要說(shuō)明了Executor模塊和ProcessUtility模塊這兩個(gè)主要的執(zhí)行分支。這里要提到兩個(gè)概念:
可優(yōu)化語(yǔ)句和非可優(yōu)化語(yǔ)句
可優(yōu)化語(yǔ)句說(shuō)白了就是DML語(yǔ)句,這些語(yǔ)句的特點(diǎn)就是都要查詢到滿足條件的元組。這類(lèi)查詢都在查詢規(guī)劃階段生成了規(guī)劃樹(shù),而規(guī)劃樹(shù)的生成過(guò)程中會(huì)根據(jù)查詢優(yōu)化理論進(jìn)行重寫(xiě)和優(yōu)化以提高查詢速度,因此稱作可優(yōu)化語(yǔ)句。
那反過(guò)來(lái)講,那些沒(méi)有生成執(zhí)行計(jì)劃樹(shù)的功能性操作就是非可優(yōu)化語(yǔ)句了。這里只是提一下這個(gè)概念,在后面的介紹中會(huì)用。