mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Add 'missing_ok' argument to build_attrmap_by_name
When it's given as true, return a 0 in the position of the missing column rather than raising an error. This is currently unused, but it allows us to reimplement column permission checking in a subsequent commit. It seems worth breaking into a separate commit because it affects unrelated code. Author: Amit Langote <amitlangote09@gmail.com> Discussion: https://postgr.es/m/CA+HiwqFfiai=qBxPDTjaio_ZcaqUKh+FC=prESrB8ogZgFNNNQ@mail.gmail.com
This commit is contained in:
		| @@ -582,7 +582,8 @@ ExecInitPartitionInfo(ModifyTableState *mtstate, EState *estate, | ||||
| 		 */ | ||||
| 		part_attmap = | ||||
| 			build_attrmap_by_name(RelationGetDescr(partrel), | ||||
| 								  RelationGetDescr(firstResultRel)); | ||||
| 								  RelationGetDescr(firstResultRel), | ||||
| 								  false); | ||||
| 		wcoList = (List *) | ||||
| 			map_variable_attnos((Node *) wcoList, | ||||
| 								firstVarno, 0, | ||||
| @@ -639,7 +640,8 @@ ExecInitPartitionInfo(ModifyTableState *mtstate, EState *estate, | ||||
| 		if (part_attmap == NULL) | ||||
| 			part_attmap = | ||||
| 				build_attrmap_by_name(RelationGetDescr(partrel), | ||||
| 									  RelationGetDescr(firstResultRel)); | ||||
| 									  RelationGetDescr(firstResultRel), | ||||
| 									  false); | ||||
| 		returningList = (List *) | ||||
| 			map_variable_attnos((Node *) returningList, | ||||
| 								firstVarno, 0, | ||||
| @@ -780,7 +782,8 @@ ExecInitPartitionInfo(ModifyTableState *mtstate, EState *estate, | ||||
| 				if (part_attmap == NULL) | ||||
| 					part_attmap = | ||||
| 						build_attrmap_by_name(RelationGetDescr(partrel), | ||||
| 											  RelationGetDescr(firstResultRel)); | ||||
| 											  RelationGetDescr(firstResultRel), | ||||
| 											  false); | ||||
| 				onconflset = (List *) | ||||
| 					map_variable_attnos((Node *) onconflset, | ||||
| 										INNER_VAR, 0, | ||||
| @@ -878,7 +881,8 @@ ExecInitPartitionInfo(ModifyTableState *mtstate, EState *estate, | ||||
| 		if (part_attmap == NULL) | ||||
| 			part_attmap = | ||||
| 				build_attrmap_by_name(RelationGetDescr(partrel), | ||||
| 									  RelationGetDescr(firstResultRel)); | ||||
| 									  RelationGetDescr(firstResultRel), | ||||
| 									  false); | ||||
|  | ||||
| 		if (unlikely(!leaf_part_rri->ri_projectNewInfoValid)) | ||||
| 			ExecInitMergeTupleSlots(mtstate, leaf_part_rri); | ||||
| @@ -1147,7 +1151,8 @@ ExecInitPartitionDispatchInfo(EState *estate, | ||||
| 		 * routing. | ||||
| 		 */ | ||||
| 		pd->tupmap = build_attrmap_by_name_if_req(RelationGetDescr(parent_pd->reldesc), | ||||
| 												  tupdesc); | ||||
| 												  tupdesc, | ||||
| 												  false); | ||||
| 		pd->tupslot = pd->tupmap ? | ||||
| 			MakeSingleTupleTableSlot(tupdesc, &TTSOpsVirtual) : NULL; | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user