mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 01:29:19 +03:00 
			
		
		
		
	Clean up range-table building in copy.c
Commit 804b6b6db4 added the build of a
range table in copy.c to initialize the EState es_range_table since it
can be needed in error paths.  Unfortunately, that commit didn't
appreciate that some code paths might end up not initializing the rte
which is used to build the range table.
Fix that and clean up a couple others things along the way- build it
only once and don't explicitly set it on the !is_from path as it
doesn't make any sense there (cstate is palloc0'd, so this isn't an
issue from an initializing standpoint either).
The prior commit went back to 9.0, but this only goes back to 9.1 as
prior to that the range table build happens immediately after building
the RTE and therefore doesn't suffer from this issue.
Pointed out by Robert.
			
			
This commit is contained in:
		| @@ -790,7 +790,7 @@ DoCopy(const CopyStmt *stmt, const char *queryString, uint64 *processed) | |||||||
| 	Relation	rel; | 	Relation	rel; | ||||||
| 	Oid			relid; | 	Oid			relid; | ||||||
| 	Node	   *query = NULL; | 	Node	   *query = NULL; | ||||||
| 	RangeTblEntry *rte; | 	List	   *range_table = NIL; | ||||||
|  |  | ||||||
| 	/* Disallow COPY to/from file or program except to superusers. */ | 	/* Disallow COPY to/from file or program except to superusers. */ | ||||||
| 	if (!pipe && !superuser()) | 	if (!pipe && !superuser()) | ||||||
| @@ -815,6 +815,7 @@ DoCopy(const CopyStmt *stmt, const char *queryString, uint64 *processed) | |||||||
| 		AclMode		required_access = (is_from ? ACL_INSERT : ACL_SELECT); | 		AclMode		required_access = (is_from ? ACL_INSERT : ACL_SELECT); | ||||||
| 		List	   *attnums; | 		List	   *attnums; | ||||||
| 		ListCell   *cur; | 		ListCell   *cur; | ||||||
|  | 		RangeTblEntry *rte; | ||||||
|  |  | ||||||
| 		Assert(!stmt->query); | 		Assert(!stmt->query); | ||||||
|  |  | ||||||
| @@ -829,6 +830,7 @@ DoCopy(const CopyStmt *stmt, const char *queryString, uint64 *processed) | |||||||
| 		rte->relid = RelationGetRelid(rel); | 		rte->relid = RelationGetRelid(rel); | ||||||
| 		rte->relkind = rel->rd_rel->relkind; | 		rte->relkind = rel->rd_rel->relkind; | ||||||
| 		rte->requiredPerms = required_access; | 		rte->requiredPerms = required_access; | ||||||
|  | 		range_table = list_make1(rte); | ||||||
|  |  | ||||||
| 		tupDesc = RelationGetDescr(rel); | 		tupDesc = RelationGetDescr(rel); | ||||||
| 		attnums = CopyGetAttnums(tupDesc, rel, stmt->attlist); | 		attnums = CopyGetAttnums(tupDesc, rel, stmt->attlist); | ||||||
| @@ -842,7 +844,7 @@ DoCopy(const CopyStmt *stmt, const char *queryString, uint64 *processed) | |||||||
| 			else | 			else | ||||||
| 				rte->selectedCols = bms_add_member(rte->selectedCols, attno); | 				rte->selectedCols = bms_add_member(rte->selectedCols, attno); | ||||||
| 		} | 		} | ||||||
| 		ExecCheckRTPerms(list_make1(rte), true); | 		ExecCheckRTPerms(range_table, true); | ||||||
|  |  | ||||||
| 		/* | 		/* | ||||||
| 		 * Permission check for row security policies. | 		 * Permission check for row security policies. | ||||||
| @@ -921,7 +923,7 @@ DoCopy(const CopyStmt *stmt, const char *queryString, uint64 *processed) | |||||||
|  |  | ||||||
| 		cstate = BeginCopyFrom(rel, stmt->filename, stmt->is_program, | 		cstate = BeginCopyFrom(rel, stmt->filename, stmt->is_program, | ||||||
| 							   stmt->attlist, stmt->options); | 							   stmt->attlist, stmt->options); | ||||||
| 		cstate->range_table = list_make1(rte); | 		cstate->range_table = range_table; | ||||||
| 		*processed = CopyFrom(cstate);	/* copy from file to database */ | 		*processed = CopyFrom(cstate);	/* copy from file to database */ | ||||||
| 		EndCopyFrom(cstate); | 		EndCopyFrom(cstate); | ||||||
| 	} | 	} | ||||||
| @@ -930,7 +932,6 @@ DoCopy(const CopyStmt *stmt, const char *queryString, uint64 *processed) | |||||||
| 		cstate = BeginCopyTo(rel, query, queryString, relid, | 		cstate = BeginCopyTo(rel, query, queryString, relid, | ||||||
| 							 stmt->filename, stmt->is_program, | 							 stmt->filename, stmt->is_program, | ||||||
| 							 stmt->attlist, stmt->options); | 							 stmt->attlist, stmt->options); | ||||||
| 		cstate->range_table = list_make1(rte); |  | ||||||
| 		*processed = DoCopyTo(cstate);	/* copy from database to file */ | 		*processed = DoCopyTo(cstate);	/* copy from database to file */ | ||||||
| 		EndCopyTo(cstate); | 		EndCopyTo(cstate); | ||||||
| 	} | 	} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user