mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Fix parsing of qualified relation names in RETURNING.
Given a qualified refname, refnameNamespaceItem() will search for a
matching namespace item by relation OID, rather than by name. Commit
80feb727c8 broke this by adding additional namespace items for OLD and
NEW in the RETURNING list, which have the same relation OID, causing
ambiguity. Fix this by ignoring these in the search, which is correct
since they don't match the qualified relation name, and so there is no
real ambiguity.
Reported by Richard Guo.
Discussion: https://postgr.es/m/CAMbWs49MBjWYWDROJ8MZ%3DY%2B4UgRQa10wzik1tWrD5yto9eoGXg%40mail.gmail.com
			
			
This commit is contained in:
		| @@ -125,7 +125,10 @@ static bool isQueryUsingTempRelation_walker(Node *node, void *context); | ||||
|  * that (a) has no alias and (b) is for the same relation identified by | ||||
|  * schemaname.refname.  In this case we convert schemaname.refname to a | ||||
|  * relation OID and search by relid, rather than by alias name.  This is | ||||
|  * peculiar, but it's what SQL says to do. | ||||
|  * peculiar, but it's what SQL says to do.  While processing a query's | ||||
|  * RETURNING list, there may be additional namespace items for OLD and NEW, | ||||
|  * with the same relation OID as the target namespace item.  These are | ||||
|  * ignored in the search, since they don't match by schemaname.refname. | ||||
|  */ | ||||
| ParseNamespaceItem * | ||||
| refnameNamespaceItem(ParseState *pstate, | ||||
| @@ -255,6 +258,9 @@ scanNameSpaceForRelid(ParseState *pstate, Oid relid, int location) | ||||
| 		/* If not inside LATERAL, ignore lateral-only items */ | ||||
| 		if (nsitem->p_lateral_only && !pstate->p_lateral_active) | ||||
| 			continue; | ||||
| 		/* Ignore OLD/NEW namespace items that can appear in RETURNING */ | ||||
| 		if (nsitem->p_returning_type != VAR_RETURNING_DEFAULT) | ||||
| 			continue; | ||||
|  | ||||
| 		/* yes, the test for alias == NULL should be there... */ | ||||
| 		if (rte->rtekind == RTE_RELATION && | ||||
|   | ||||
		Reference in New Issue
	
	Block a user