這篇文章主要講解了“PostgreSQL執(zhí)行聚合函數(shù)所使用的數(shù)據(jù)結(jié)構(gòu)有哪些”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“PostgreSQL執(zhí)行聚合函數(shù)所使用的數(shù)據(jù)結(jié)構(gòu)有哪些”吧!
專注于為中小企業(yè)提供網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)津南免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上1000+企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
AggState
聚合函數(shù)執(zhí)行時狀態(tài)結(jié)構(gòu)體,內(nèi)含AggStatePerAgg等結(jié)構(gòu)體
/* --------------------- * AggState information * * ss.ss_ScanTupleSlot refers to output of underlying plan. * ss.ss_ScanTupleSlot指的是基礎(chǔ)計劃的輸出. * (ss = ScanState,ps = PlanState) * * Note: ss.ps.ps_ExprContext contains ecxt_aggvalues and * ecxt_aggnulls arrays, which hold the computed agg values for the current * input group during evaluation of an Agg node's output tuple(s). We * create a second ExprContext, tmpcontext, in which to evaluate input * expressions and run the aggregate transition functions. * 注意:ss.ps.ps_ExprContext包含了ecxt_aggvalues和ecxt_aggnulls數(shù)組, * 這兩個數(shù)組保存了在計算agg節(jié)點的輸出元組時當(dāng)前輸入組已計算的agg值. * --------------------- */ /* these structs are private in nodeAgg.c: */ //在nodeAgg.c中私有的結(jié)構(gòu)體 typedef struct AggStatePerAggData *AggStatePerAgg; typedef struct AggStatePerTransData *AggStatePerTrans; typedef struct AggStatePerGroupData *AggStatePerGroup; typedef struct AggStatePerPhaseData *AggStatePerPhase; typedef struct AggStatePerHashData *AggStatePerHash; typedef struct AggState { //第一個字段是NodeTag(繼承自ScanState) ScanState ss; /* its first field is NodeTag */ //targetlist和quals中所有的Aggref List *aggs; /* all Aggref nodes in targetlist & quals */ //鏈表的大小(可以為0) int numaggs; /* length of list (could be zero!) */ //pertrans條目大小 int numtrans; /* number of pertrans items */ //Agg策略模式 AggStrategy aggstrategy; /* strategy mode */ //agg-splitting模式,參見nodes.h AggSplit aggsplit; /* agg-splitting mode, see nodes.h */ //指向當(dāng)前步驟數(shù)據(jù)的指針 AggStatePerPhase phase; /* pointer to current phase data */ //步驟數(shù)(包括0) int numphases; /* number of phases (including phase 0) */ //當(dāng)前步驟 int current_phase; /* current phase number */ //per-Aggref信息 AggStatePerAgg peragg; /* per-Aggref information */ //per-Trans狀態(tài)信息 AggStatePerTrans pertrans; /* per-Trans state information */ //長生命周期數(shù)據(jù)的ExprContexts(hashtable) ExprContext *hashcontext; /* econtexts for long-lived data (hashtable) */ ////長生命周期數(shù)據(jù)的ExprContexts(每一個GS使用) ExprContext **aggcontexts; /* econtexts for long-lived data (per GS) */ //輸入表達式的ExprContext ExprContext *tmpcontext; /* econtext for input expressions */ #define FIELDNO_AGGSTATE_CURAGGCONTEXT 14 //當(dāng)前活躍的aggcontext ExprContext *curaggcontext; /* currently active aggcontext */ //當(dāng)前活躍的aggregate(如存在) AggStatePerAgg curperagg; /* currently active aggregate, if any */ #define FIELDNO_AGGSTATE_CURPERTRANS 16 //當(dāng)前活躍的trans state AggStatePerTrans curpertrans; /* currently active trans state, if any */ //輸入結(jié)束? bool input_done; /* indicates end of input */ //Agg掃描結(jié)束? bool agg_done; /* indicates completion of Agg scan */ //最后一個grouping set int projected_set; /* The last projected grouping set */ #define FIELDNO_AGGSTATE_CURRENT_SET 20 //將要解析的當(dāng)前grouping set int current_set; /* The current grouping set being evaluated */ //當(dāng)前投影操作的分組列 Bitmapset *grouped_cols; /* grouped cols in current projection */ //倒序的分組列鏈表 List *all_grouped_cols; /* list of all grouped cols in DESC order */ /* These fields are for grouping set phase data */ //-------- 下面的列用于grouping set步驟數(shù)據(jù) //所有步驟中最大的sets大小 int maxsets; /* The max number of sets in any phase */ //所有步驟的數(shù)組 AggStatePerPhase phases; /* array of all phases */ //對于phases > 1,已排序的輸入信息 Tuplesortstate *sort_in; /* sorted input to phases > 1 */ //對于下一個步驟,輸入已拷貝 Tuplesortstate *sort_out; /* input is copied here for next phase */ //排序結(jié)果的slot TupleTableSlot *sort_slot; /* slot for sort results */ /* these fields are used in AGG_PLAIN and AGG_SORTED modes: */ //------- 下面的列用于AGG_PLAIN和AGG_SORTED模式: //per-group指針的grouping set編號數(shù)組 AggStatePerGroup *pergroups; /* grouping set indexed array of per-group * pointers */ //當(dāng)前組的第一個元組拷貝 HeapTuple grp_firstTuple; /* copy of first tuple of current group */ /* these fields are used in AGG_HASHED and AGG_MIXED modes: */ //--------- 下面的列用于AGG_HASHED和AGG_MIXED模式: //是否已填充hash表? bool table_filled; /* hash table filled yet? */ //hash桶數(shù)? int num_hashes; //相應(yīng)的哈希表數(shù)據(jù)數(shù)組 AggStatePerHash perhash; /* array of per-hashtable data */ //per-group指針的grouping set編號數(shù)組 AggStatePerGroup *hash_pergroup; /* grouping set indexed array of * per-group pointers */ /* support for evaluation of agg input expressions: */ //---------- agg輸入表達式解析支持 #define FIELDNO_AGGSTATE_ALL_PERGROUPS 34 //首先是->pergroups,然后是hash_pergroup AggStatePerGroup *all_pergroups; /* array of first ->pergroups, than * ->hash_pergroup */ //投影實現(xiàn)機制 ProjectionInfo *combinedproj; /* projection machinery */ } AggState; /* Primitive options supported by nodeAgg.c: */ //nodeag .c支持的基本選項 #define AGGSPLITOP_COMBINE 0x01 /* substitute combinefn for transfn */ #define AGGSPLITOP_SKIPFINAL 0x02 /* skip finalfn, return state as-is */ #define AGGSPLITOP_SERIALIZE 0x04 /* apply serializefn to output */ #define AGGSPLITOP_DESERIALIZE 0x08 /* apply deserializefn to input */ /* Supported operating modes (i.e., useful combinations of these options): */ //支持的操作模式 typedef enum AggSplit { /* Basic, non-split aggregation: */ //基本 : 非split聚合 AGGSPLIT_SIMPLE = 0, /* Initial phase of partial aggregation, with serialization: */ //部分聚合的初始步驟,序列化 AGGSPLIT_INITIAL_SERIAL = AGGSPLITOP_SKIPFINAL | AGGSPLITOP_SERIALIZE, /* Final phase of partial aggregation, with deserialization: */ //部分聚合的最終步驟,反序列化 AGGSPLIT_FINAL_DESERIAL = AGGSPLITOP_COMBINE | AGGSPLITOP_DESERIALIZE } AggSplit; /* Test whether an AggSplit value selects each primitive option: */ //測試AggSplit選擇了哪些基本選項 #define DO_AGGSPLIT_COMBINE(as) (((as) & AGGSPLITOP_COMBINE) != 0) #define DO_AGGSPLIT_SKIPFINAL(as) (((as) & AGGSPLITOP_SKIPFINAL) != 0) #define DO_AGGSPLIT_SERIALIZE(as) (((as) & AGGSPLITOP_SERIALIZE) != 0) #define DO_AGGSPLIT_DESERIALIZE(as) (((as) & AGGSPLITOP_DESERIALIZE) != 0)
AggStatePerAggData
per-aggregate信息,這個結(jié)構(gòu)體包含了調(diào)用最終函數(shù)的信息,用以從狀態(tài)值中產(chǎn)生一個最終的聚合結(jié)果.如果查詢中有多個相同的Aggrefs,共享相同的per-agg數(shù)據(jù).
/* * AggStatePerAggData - per-aggregate information * AggStatePerAggData - per-aggregate信息 * * This contains the information needed to call the final function, to produce * a final aggregate result from the state value. If there are multiple * identical Aggrefs in the query, they can all share the same per-agg data. * 這個結(jié)構(gòu)體包含了調(diào)用最終函數(shù)的信息,用以從狀態(tài)值中產(chǎn)生一個最終的聚合結(jié)果. * 如果查詢中有多個相同的Aggrefs,共享相同的per-agg數(shù)據(jù). * * These values are set up during ExecInitAgg() and do not change thereafter. * 這些值在ExecInitAgg()中設(shè)置,此后不再變化. */ typedef struct AggStatePerAggData { /* * Link to an Aggref expr this state value is for. * 鏈接到該狀態(tài)值代表的Aggref expr上. * * There can be multiple identical Aggref's sharing the same per-agg. This * points to the first one of them. * 可能有多個相同的Aggref共享相同的per-agg.指向第一個. */ Aggref *aggref; /* index to the state value which this agg should use */ //該agg應(yīng)使用的狀態(tài)值索引 int transno; /* Optional Oid of final function (may be InvalidOid) */ //final function函數(shù)的Oid(可以是InvalidOid) Oid finalfn_oid; /* * fmgr lookup data for final function --- only valid when finalfn_oid is * not InvalidOid. * final function的fmgr檢索數(shù)據(jù) --- 在finalfn_oid不是InvalidOid時才有效 */ FmgrInfo finalfn; /* * Number of arguments to pass to the finalfn. This is always at least 1 * (the transition state value) plus any ordered-set direct args. If the * finalfn wants extra args then we pass nulls corresponding to the * aggregated input columns. * 傳遞給finalfn的參數(shù)個數(shù). * 這通常不小于1(轉(zhuǎn)換狀態(tài)值)加上所有已排序集合的直接參數(shù). * 如果finalfn需要特別的參數(shù),那么會傳遞nulls對應(yīng)聚合的輸入列. * */ int numFinalArgs; /* ExprStates for any direct-argument expressions */ //所有直接參數(shù)表達式的ExprStates List *aggdirectargs; /* * We need the len and byval info for the agg's result data type in order * to know how to copy/delete values. * 對于agg結(jié)果數(shù)據(jù)類型需要長度和byval信息,用以知道如何拷貝和刪除值. */ int16 resulttypeLen; bool resulttypeByVal; /* * "shareable" is false if this agg cannot share state values with other * aggregates because the final function is read-write. * 如因為final function是RW,agg不能與其他aggregates共享狀態(tài)值,則shareable為F */ bool shareable; } AggStatePerAggData;
AggStatePerTransData
聚合狀態(tài)值信息(per aggregate state value information), 通過輸入行調(diào)用轉(zhuǎn)換函數(shù)更新聚合狀態(tài)值的工作狀態(tài).該結(jié)構(gòu)體不會存儲從轉(zhuǎn)換狀態(tài)而來的用于產(chǎn)生最終聚合結(jié)果的相關(guān)信息,這些信息會存儲在AggStatePerAggData中.
/* * AggStatePerTransData - per aggregate state value information * AggStatePerTransData - 聚合狀態(tài)值信息 * * Working state for updating the aggregate's state value, by calling the * transition function with an input row. This struct does not store the * information needed to produce the final aggregate result from the transition * state, that's stored in AggStatePerAggData instead. This separation allows * multiple aggregate results to be produced from a single state value. * 通過輸入行調(diào)用轉(zhuǎn)換函數(shù)更新聚合狀態(tài)值的工作狀態(tài). * 該結(jié)構(gòu)體不會存儲從轉(zhuǎn)換狀態(tài)而來的用于產(chǎn)生最終聚合結(jié)果的相關(guān)信息,這些信息會存儲在AggStatePerAggData中. * 這樣的分離可以做到多個聚合結(jié)果可通過單個狀態(tài)值產(chǎn)生. */ typedef struct AggStatePerTransData { /* * These values are set up during ExecInitAgg() and do not change * thereafter: * 這些值在ExecInitAgg()執(zhí)行期間設(shè)置,以后不會修改. */ /* * Link to an Aggref expr this state value is for. * 鏈接到該狀態(tài)值所代表的Aggref表達式上面. * * There can be multiple Aggref's sharing the same state value, so long as * the inputs and transition functions are identical and the final * functions are not read-write. This points to the first one of them. * 參見AggStatePerAggData結(jié)構(gòu)體注釋 */ Aggref *aggref; /* * Is this state value actually being shared by more than one Aggref? * 是否共享? */ bool aggshared; /* * Number of aggregated input columns. This includes ORDER BY expressions * in both the plain-agg and ordered-set cases. Ordered-set direct args * are not counted, though. * 聚合輸入列個數(shù). */ int numInputs; /* * Number of aggregated input columns to pass to the transfn. This * includes the ORDER BY columns for ordered-set aggs, but not for plain * aggs. (This doesn't count the transition state value!) * 傳遞給transfn的聚合輸入列個數(shù). */ int numTransInputs; /* Oid of the state transition or combine function */ //轉(zhuǎn)換或組合函數(shù)Oid Oid transfn_oid; /* Oid of the serialization function or InvalidOid */ //序列化函數(shù)Oid或InvalidOid Oid serialfn_oid; /* Oid of the deserialization function or InvalidOid */ //反序列化函數(shù)Oid或InvalidOid Oid deserialfn_oid; /* Oid of state value's datatype */ //狀態(tài)值數(shù)據(jù)類型Oid Oid aggtranstype; /* * fmgr lookup data for transition function or combine function. Note in * particular that the fn_strict flag is kept here. * 轉(zhuǎn)換函數(shù)或組合函數(shù)的fmgr檢索數(shù)據(jù). */ FmgrInfo transfn; /* fmgr lookup data for serialization function */ //序列化函數(shù)fmgr FmgrInfo serialfn; /* fmgr lookup data for deserialization function */ //反序列化函數(shù)fmgr FmgrInfo deserialfn; /* Input collation derived for aggregate */ //派生于聚合的輸入排序規(guī)則 Oid aggCollation; /* number of sorting columns */ //排序列個數(shù) int numSortCols; /* number of sorting columns to consider in DISTINCT comparisons */ /* (this is either zero or the same as numSortCols) */ //在DISTINCT比較時需考慮的排序列數(shù) int numDistinctCols; /* deconstructed sorting information (arrays of length numSortCols) */ //重組排序信息 AttrNumber *sortColIdx; Oid *sortOperators; Oid *sortCollations; bool *sortNullsFirst; /* * Comparators for input columns --- only set/used when aggregate has * DISTINCT flag. equalfnOne version is used for single-column * comparisons, equalfnMulti for the case of multiple columns. * 輸入列比較器,在聚合有DISTINCT標(biāo)記時才會設(shè)置/使用 * equalfnOne用于單個列比較,equalfnMulti用于多列. */ FmgrInfo equalfnOne; ExprState *equalfnMulti; /* * initial value from pg_aggregate entry * pg_aggregate條目的初始值 */ Datum initValue; bool initValueIsNull; /* * We need the len and byval info for the agg's input and transition data * types in order to know how to copy/delete values. * 需要聚合輸入的len和byval信息以及轉(zhuǎn)換數(shù)據(jù)類型,以便知道如何拷貝/刪除值 * * Note that the info for the input type is used only when handling * DISTINCT aggs with just one argument, so there is only one input type. * 注意:輸入類型的信息僅用于處理單個參數(shù)的DISTINCT聚合,因此只有一個輸入類型 */ int16 inputtypeLen, transtypeLen; bool inputtypeByVal, transtypeByVal; /* * Slots for holding the evaluated input arguments. These are set up * during ExecInitAgg() and then used for each input row requiring either * FILTER or ORDER BY/DISTINCT processing. * 保存解析輸入?yún)?shù)的slots. * 在ExecInitAgg()中設(shè)置用于每個輸入行,在FILTER或ORDER BY/DISTINCT處理過程中需要. */ //當(dāng)前輸入的tuple TupleTableSlot *sortslot; /* current input tuple */ //用于多列DISTINCT TupleTableSlot *uniqslot; /* used for multi-column DISTINCT */ //輸入元組描述符 TupleDesc sortdesc; /* descriptor of input tuples */ /* * These values are working state that is initialized at the start of an * input tuple group and updated for each input tuple. * 這些值是在輸入tuple group被初始化時的工作狀態(tài),在處理每個tuple都會更新. * * For a simple (non DISTINCT/ORDER BY) aggregate, we just feed the input * values straight to the transition function. If it's DISTINCT or * requires ORDER BY, we pass the input values into a Tuplesort object; * then at completion of the input tuple group, we scan the sorted values, * eliminate duplicates if needed, and run the transition function on the * rest. * 對于簡單的(不是DISTINCT/ORDER BY)聚合,直接把輸入值提供給轉(zhuǎn)換函數(shù)即可. * 如果是DISTINCT/ORDER BY,傳遞輸入值給Tuplesort對象, * 在輸入的tuple組結(jié)束時,掃描已存儲值,如需要去重并在剩余的元組上執(zhí)行轉(zhuǎn)換函數(shù) * * We need a separate tuplesort for each grouping set. * 需要為每一個grouping set提供tuplesort */ //排序?qū)ο?僅用于DISTINCT/ORDER BY Tuplesortstate **sortstates; /* sort objects, if DISTINCT or ORDER BY */ /* * This field is a pre-initialized FunctionCallInfo struct used for * calling this aggregate's transfn. We save a few cycles per row by not * re-initializing the unchanging fields; which isn't much, but it seems * worth the extra space consumption. * 該字段是預(yù)初始化FunctionCallInfo結(jié)構(gòu)體,用于調(diào)用聚合的轉(zhuǎn)換函數(shù)transfn. * 對于每一行,通過減少不會改變的字段的初始化可以節(jié)省一些CPU處理周期, * 但這個收益不會太大,但看起來值得額外的空間消耗. */ FunctionCallInfoData transfn_fcinfo; /* Likewise for serialization and deserialization functions */ //序列化和反序列化函數(shù)信息 FunctionCallInfoData serialfn_fcinfo; FunctionCallInfoData deserialfn_fcinfo; } AggStatePerTransData;
AggStatePerGroupData
per-aggregate-per-group工作狀態(tài),這些工作狀態(tài)值在第一個輸入tuple group時初始化,后續(xù)在處理每個輸入tuple時更新.
/* * AggStatePerGroupData - per-aggregate-per-group working state * AggStatePerGroupData - per-aggregate-per-group工作狀態(tài) * * These values are working state that is initialized at the start of * an input tuple group and updated for each input tuple. * 這些工作狀態(tài)值在第一個輸入tuple group時初始化,后續(xù)在處理每個輸入tuple時更新. * * In AGG_PLAIN and AGG_SORTED modes, we have a single array of these * structs (pointed to by aggstate->pergroup); we re-use the array for * each input group, if it's AGG_SORTED mode. In AGG_HASHED mode, the * hash table contains an array of these structs for each tuple group. * 在AGG_PLAIN/AGG_SORTED模式,這些結(jié)構(gòu)體都有一個單獨的數(shù)組(aggstate->pergroup指向這些結(jié)構(gòu)體); * 在AGG_SORTED模式,對于每一個輸入group,都會重用這些數(shù)組. * 在AGG_HASHED模式,hash表中都有對應(yīng)每一個tuple group的這些結(jié)構(gòu)體的數(shù)組. * * Logically, the sortstate field belongs in this struct, but we do not * keep it here for space reasons: we don't support DISTINCT aggregates * in AGG_HASHED mode, so there's no reason to use up a pointer field * in every entry of the hashtable. * 邏輯上來說,sortstate字段屬于該結(jié)構(gòu)體,但出于空間大小考慮,不在這里保存: * 在AGG_HASHED模式,不支持DISTINCT聚合,因此沒有理由在hash表的每一個條目中都包含指針域. */ typedef struct AggStatePerGroupData { #define FIELDNO_AGGSTATEPERGROUPDATA_TRANSVALUE 0 //當(dāng)前轉(zhuǎn)換值 Datum transValue; /* current transition value */ #define FIELDNO_AGGSTATEPERGROUPDATA_TRANSVALUEISNULL 1 bool transValueIsNull; #define FIELDNO_AGGSTATEPERGROUPDATA_NOTRANSVALUE 2 //如transValue尚未設(shè)置,則為T bool noTransValue; /* true if transValue not set yet */ /* * Note: noTransValue initially has the same value as transValueIsNull, * and if true both are cleared to false at the same time. They are not * the same though: if transfn later returns a NULL, we want to keep that * NULL and not auto-replace it with a later input value. Only the first * non-NULL input will be auto-substituted. * 注意:noTransValue與transValueIsNull在初始化時值一樣,如同為T,則同時將二者設(shè)置為F. * 但它們并不相同,如果transfn后續(xù)返回NULL,需要保存該NULL值而不是用隨后的輸入值自動替換之. * 只有在第一個非NULL輸入會被自動替換. */ } AggStatePerGroupData;
AggStatePerPhaseData
per-grouping-set-phase狀態(tài).Grouping sets會被分拆為多個”步驟”,每一個單獨的步驟在輸入上都會完成一輪處理.
/* * AggStatePerPhaseData - per-grouping-set-phase state * AggStatePerPhaseData - per-grouping-set-phase狀態(tài) * * Grouping sets are divided into "phases", where a single phase can be * processed in one pass over the input. If there is more than one phase, then * at the end of input from the current phase, state is reset and another pass * taken over the data which has been re-sorted in the mean time. * Grouping sets會被分拆為多個"步驟",每一個單獨的步驟在輸入上都會完成一輪處理. * 如果步驟多于一個,在當(dāng)前步驟的最后一個輸入處,狀態(tài)會被重置,同時另一次傳遞接管了在此期間重排的數(shù)據(jù). * * Accordingly, each phase specifies a list of grouping sets and group clause * information, plus each phase after the first also has a sort order. * 相應(yīng)的,每一個步驟指定了grouping sets和group clause信息鏈表,外加在第一個步驟的排序. */ typedef struct AggStatePerPhaseData { //該步驟使用的策略 AggStrategy aggstrategy; /* strategy for this phase */ //grouping sets個數(shù),如無則為0 int numsets; /* number of grouping sets (or 0) */ //grouping sets的大小 int *gset_lengths; /* lengths of grouping sets */ //rollup(上卷)列組 Bitmapset **grouped_cols; /* column groupings for rollup */ //返回等價的表達式,比較列序號作為索引 ExprState **eqfunctions; /* expression returning equality, indexed by * nr of cols to compare */ //對應(yīng)步驟數(shù)據(jù)的Agg節(jié)點 Agg *aggnode; /* Agg node for phase data */ //該步驟的輸入排序Sort節(jié)點 Sort *sortnode; /* Sort node for input ordering for phase */ //轉(zhuǎn)換函數(shù)解析 ExprState *evaltrans; /* evaluation of transition functions */ } AggStatePerPhaseData;
AggStatePerHashData
per-hashtable狀態(tài).使用哈希進行g(shù)rouping set,每一個grouping set都會有一個這樣的結(jié)構(gòu)體.
/* * AggStatePerHashData - per-hashtable state * AggStatePerHashData - per-hashtable狀態(tài) * * When doing grouping sets with hashing, we have one of these for each * grouping set. (When doing hashing without grouping sets, we have just one of * them.) * 使用哈希進行g(shù)rouping set,每一個grouping set都會有一個這樣的結(jié)構(gòu)體. * (如無grouping sets執(zhí)行哈希,則只需要一個即可) */ typedef struct AggStatePerHashData { //每一個group都有一個條目的哈希表 TupleHashTable hashtable; /* hash table with one entry per group */ //訪問哈希表的迭代器 TupleHashIterator hashiter; /* for iterating through hash table */ //裝載哈希表的slot TupleTableSlot *hashslot; /* slot for loading hash table */ //per-grouping-field哈希函數(shù) FmgrInfo *hashfunctions; /* per-grouping-field hash fns */ //per-grouping-field等價函數(shù) Oid *eqfuncoids; /* per-grouping-field equality fns */ //哈希鍵列個數(shù) int numCols; /* number of hash key columns */ //哈希表中的列數(shù) int numhashGrpCols; /* number of columns in hash table */ //請求哈希最大的列 int largestGrpColIdx; /* largest col required for hashing */ //輸入slot中的hash col索引數(shù)組 AttrNumber *hashGrpColIdxInput; /* hash col indices in input slot */ //hashtbl元組索引數(shù)組 AttrNumber *hashGrpColIdxHash; /* indices in hashtbl tuples */ //元素的Agg節(jié)點,用于numGroups等等 Agg *aggnode; /* original Agg node, for numGroups etc. */ } AggStatePerHashData;
感謝各位的閱讀,以上就是“PostgreSQL執(zhí)行聚合函數(shù)所使用的數(shù)據(jù)結(jié)構(gòu)有哪些”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對PostgreSQL執(zhí)行聚合函數(shù)所使用的數(shù)據(jù)結(jié)構(gòu)有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!