mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-21 02:52:47 +03:00 
			
		
		
		
	Tighten up sanity checks for parallel aggregate in execQual.c.
David Rowley
This commit is contained in:
		| @@ -4510,28 +4510,35 @@ ExecInitExpr(Expr *node, PlanState *parent) | |||||||
| 		case T_Aggref: | 		case T_Aggref: | ||||||
| 			{ | 			{ | ||||||
| 				AggrefExprState *astate = makeNode(AggrefExprState); | 				AggrefExprState *astate = makeNode(AggrefExprState); | ||||||
|  | 				AggState   *aggstate = (AggState *) parent; | ||||||
|  | 				Aggref	   *aggref = (Aggref *) node; | ||||||
|  |  | ||||||
| 				astate->xprstate.evalfunc = (ExprStateEvalFunc) ExecEvalAggref; | 				astate->xprstate.evalfunc = (ExprStateEvalFunc) ExecEvalAggref; | ||||||
| 				if (parent && IsA(parent, AggState)) | 				if (!aggstate || !IsA(aggstate, AggState)) | ||||||
| 				{ |  | ||||||
| 					AggState   *aggstate = (AggState *) parent; |  | ||||||
| 					Aggref	   *aggref = (Aggref *) node; |  | ||||||
|  |  | ||||||
| 					if (aggstate->finalizeAggs && |  | ||||||
| 						aggref->aggoutputtype != aggref->aggtype) |  | ||||||
| 					{ |  | ||||||
| 						/* planner messed up */ |  | ||||||
| 						elog(ERROR, "Aggref aggoutputtype must match aggtype"); |  | ||||||
| 					} |  | ||||||
|  |  | ||||||
| 					aggstate->aggs = lcons(astate, aggstate->aggs); |  | ||||||
| 					aggstate->numaggs++; |  | ||||||
| 				} |  | ||||||
| 				else |  | ||||||
| 				{ | 				{ | ||||||
| 					/* planner messed up */ | 					/* planner messed up */ | ||||||
| 					elog(ERROR, "Aggref found in non-Agg plan node"); | 					elog(ERROR, "Aggref found in non-Agg plan node"); | ||||||
| 				} | 				} | ||||||
|  | 				if (aggref->aggpartial == aggstate->finalizeAggs) | ||||||
|  | 				{ | ||||||
|  | 					/* planner messed up */ | ||||||
|  | 					if (aggref->aggpartial) | ||||||
|  | 						elog(ERROR, "partial Aggref found in finalize agg plan node"); | ||||||
|  | 					else | ||||||
|  | 						elog(ERROR, "non-partial Aggref found in non-finalize agg plan node"); | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				if (aggref->aggcombine != aggstate->combineStates) | ||||||
|  | 				{ | ||||||
|  | 					/* planner messed up */ | ||||||
|  | 					if (aggref->aggcombine) | ||||||
|  | 						elog(ERROR, "combine Aggref found in non-combine agg plan node"); | ||||||
|  | 					else | ||||||
|  | 						elog(ERROR, "non-combine Aggref found in combine agg plan node"); | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				aggstate->aggs = lcons(astate, aggstate->aggs); | ||||||
|  | 				aggstate->numaggs++; | ||||||
| 				state = (ExprState *) astate; | 				state = (ExprState *) astate; | ||||||
| 			} | 			} | ||||||
| 			break; | 			break; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user