mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Repair bug #2839: the various ExecReScan functions need to reset
ps_TupFromTlist in plan nodes that make use of it. This was being done correctly in join nodes and Result nodes but not in any relation-scan nodes. Bug would lead to bogus results if a set-returning function appeared in the targetlist of a subquery that could be rescanned after partial execution, for example a subquery within EXISTS(). Bug has been around forever :-( ... surprising it wasn't reported before.
This commit is contained in:
		| @@ -8,7 +8,7 @@ | ||||
|  * | ||||
|  * | ||||
|  * IDENTIFICATION | ||||
|  *	  $PostgreSQL: pgsql/src/backend/executor/nodeIndexscan.c,v 1.118 2006/12/23 00:43:09 tgl Exp $ | ||||
|  *	  $PostgreSQL: pgsql/src/backend/executor/nodeIndexscan.c,v 1.119 2006/12/26 19:26:45 tgl Exp $ | ||||
|  * | ||||
|  *------------------------------------------------------------------------- | ||||
|  */ | ||||
| @@ -168,6 +168,8 @@ ExecIndexReScan(IndexScanState *node, ExprContext *exprCtxt) | ||||
| 	econtext = node->iss_RuntimeContext;		/* context for runtime keys */ | ||||
| 	scanrelid = ((IndexScan *) node->ss.ps.plan)->scan.scanrelid; | ||||
|  | ||||
| 	node->ss.ps.ps_TupFromTlist = false; | ||||
|  | ||||
| 	if (econtext) | ||||
| 	{ | ||||
| 		/* | ||||
| @@ -476,6 +478,8 @@ ExecInitIndexScan(IndexScan *node, EState *estate, int eflags) | ||||
| 	 */ | ||||
| 	ExecAssignExprContext(estate, &indexstate->ss.ps); | ||||
|  | ||||
| 	indexstate->ss.ps.ps_TupFromTlist = false; | ||||
|  | ||||
| 	/* | ||||
| 	 * initialize child expressions | ||||
| 	 * | ||||
|   | ||||
		Reference in New Issue
	
	Block a user