mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Get rid of ExecAssignResultTypeFromOuterPlan() and make all plan node types
generate their output tuple descriptors from their target lists (ie, using ExecAssignResultTypeFromTL()). We long ago fixed things so that all node types have minimally valid tlists, so there's no longer any good reason to have two different ways of doing it. This change is needed to fix bug reported by Hayden James: the fix of 2005-11-03 to emit the correct column names after optimizing away a SubqueryScan node didn't work if the new top-level plan node used ExecAssignResultTypeFromOuterPlan to generate its tupdesc, since the next plan node down won't have the correct column labels.
This commit is contained in:
		| @@ -8,7 +8,7 @@ | ||||
|  * | ||||
|  * | ||||
|  * IDENTIFICATION | ||||
|  *	  $PostgreSQL: pgsql/src/backend/executor/nodeLimit.c,v 1.22 2005/10/15 02:49:17 momjian Exp $ | ||||
|  *	  $PostgreSQL: pgsql/src/backend/executor/nodeLimit.c,v 1.23 2005/11/23 20:27:57 tgl Exp $ | ||||
|  * | ||||
|  *------------------------------------------------------------------------- | ||||
|  */ | ||||
| @@ -327,7 +327,7 @@ ExecInitLimit(Limit *node, EState *estate) | ||||
| 	 * limit nodes do no projections, so initialize projection info for this | ||||
| 	 * node appropriately | ||||
| 	 */ | ||||
| 	ExecAssignResultTypeFromOuterPlan(&limitstate->ps); | ||||
| 	ExecAssignResultTypeFromTL(&limitstate->ps); | ||||
| 	limitstate->ps.ps_ProjInfo = NULL; | ||||
|  | ||||
| 	return limitstate; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user