mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-22 14:32:25 +03:00 
			
		
		
		
	Fix oversight in check_ungrouped_columns optimization that avoids
unnecessary checks for complex grouping expressions: we cannot check whether the expressions are simple Vars until after we apply flatten_join_alias_vars, because in the case of FULL JOIN that routine can introduce non-Var expressions. Per example from Joel Knight.
This commit is contained in:
		| @@ -8,7 +8,7 @@ | ||||
|  * | ||||
|  * | ||||
|  * IDENTIFICATION | ||||
|  *	  $Header: /cvsroot/pgsql/src/backend/parser/parse_agg.c,v 1.59 2003/09/25 15:58:06 tgl Exp $ | ||||
|  *	  $Header: /cvsroot/pgsql/src/backend/parser/parse_agg.c,v 1.59.2.1 2004/01/28 07:47:07 tgl Exp $ | ||||
|  * | ||||
|  *------------------------------------------------------------------------- | ||||
|  */ | ||||
| @@ -98,7 +98,7 @@ void | ||||
| parseCheckAggregates(ParseState *pstate, Query *qry) | ||||
| { | ||||
| 	List	   *groupClauses = NIL; | ||||
| 	bool		have_non_var_grouping = false; | ||||
| 	bool		have_non_var_grouping; | ||||
| 	List	   *lst; | ||||
| 	bool		hasJoinRTEs; | ||||
| 	Node	   *clause; | ||||
| @@ -127,9 +127,7 @@ parseCheckAggregates(ParseState *pstate, Query *qry) | ||||
| 	 * No aggregates allowed in GROUP BY clauses, either. | ||||
| 	 * | ||||
| 	 * While we are at it, build a list of the acceptable GROUP BY | ||||
| 	 * expressions for use by check_ungrouped_columns() (this avoids | ||||
| 	 * repeated scans of the targetlist within the recursive routine...). | ||||
| 	 * And detect whether any of the expressions aren't simple Vars. | ||||
| 	 * expressions for use by check_ungrouped_columns(). | ||||
| 	 */ | ||||
| 	foreach(lst, qry->groupClause) | ||||
| 	{ | ||||
| @@ -144,8 +142,6 @@ parseCheckAggregates(ParseState *pstate, Query *qry) | ||||
| 					(errcode(ERRCODE_GROUPING_ERROR), | ||||
| 				   errmsg("aggregates not allowed in GROUP BY clause"))); | ||||
| 		groupClauses = lcons(expr, groupClauses); | ||||
| 		if (!IsA(expr, Var)) | ||||
| 			have_non_var_grouping = true; | ||||
| 	} | ||||
|  | ||||
| 	/* | ||||
| @@ -170,6 +166,21 @@ parseCheckAggregates(ParseState *pstate, Query *qry) | ||||
| 		groupClauses = (List *) flatten_join_alias_vars(qry, | ||||
| 												  (Node *) groupClauses); | ||||
|  | ||||
| 	/* | ||||
| 	 * Detect whether any of the grouping expressions aren't simple Vars; | ||||
| 	 * if they're all Vars then we don't have to work so hard in the | ||||
| 	 * recursive scans.  (Note we have to flatten aliases before this.) | ||||
| 	 */ | ||||
| 	have_non_var_grouping = false; | ||||
| 	foreach(lst, groupClauses) | ||||
| 	{ | ||||
| 		if (!IsA((Node *) lfirst(lst), Var)) | ||||
| 		{ | ||||
| 			have_non_var_grouping = true; | ||||
| 			break; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/* | ||||
| 	 * Check the targetlist and HAVING clause for ungrouped variables. | ||||
| 	 */ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user