mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-21 02:52:47 +03:00 
			
		
		
		
	Let table AM insertion methods control index insertion
Previously, the executor did index insert unconditionally after calling table AM interface methods tuple_insert() and multi_insert(). This commit introduces the new parameter insert_indexes for these two methods. Setting '*insert_indexes' to true saves the current logic. Setting it to false indicates that table AM cares about index inserts itself and doesn't want the caller to do that. Discussion: https://postgr.es/m/CAPpHfdurb9ycV8udYqM%3Do0sPS66PJ4RCBM1g-bBpvzUfogY0EA%40mail.gmail.com Reviewed-by: Pavel Borisov, Matthias van de Meent, Mark Dilger
This commit is contained in:
		| @@ -509,6 +509,7 @@ ExecSimpleRelationInsert(ResultRelInfo *resultRelInfo, | ||||
| 	if (!skip_tuple) | ||||
| 	{ | ||||
| 		List	   *recheckIndexes = NIL; | ||||
| 		bool		insertIndexes; | ||||
|  | ||||
| 		/* Compute stored generated columns */ | ||||
| 		if (rel->rd_att->constr && | ||||
| @@ -523,9 +524,10 @@ ExecSimpleRelationInsert(ResultRelInfo *resultRelInfo, | ||||
| 			ExecPartitionCheck(resultRelInfo, slot, estate, true); | ||||
|  | ||||
| 		/* OK, store the tuple and create index entries for it */ | ||||
| 		simple_table_tuple_insert(resultRelInfo->ri_RelationDesc, slot); | ||||
| 		simple_table_tuple_insert(resultRelInfo->ri_RelationDesc, slot, | ||||
| 								  &insertIndexes); | ||||
|  | ||||
| 		if (resultRelInfo->ri_NumIndices > 0) | ||||
| 		if (insertIndexes && resultRelInfo->ri_NumIndices > 0) | ||||
| 			recheckIndexes = ExecInsertIndexTuples(resultRelInfo, | ||||
| 												   slot, estate, false, false, | ||||
| 												   NULL, NIL, false); | ||||
|   | ||||
| @@ -1135,13 +1135,15 @@ ExecInsert(ModifyTableContext *context, | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			bool		insertIndexes; | ||||
|  | ||||
| 			/* insert the tuple normally */ | ||||
| 			slot = table_tuple_insert(resultRelationDesc, slot, | ||||
| 									  estate->es_output_cid, | ||||
| 									  0, NULL); | ||||
| 									  0, NULL, &insertIndexes); | ||||
|  | ||||
| 			/* insert index entries for tuple */ | ||||
| 			if (resultRelInfo->ri_NumIndices > 0) | ||||
| 			if (insertIndexes && resultRelInfo->ri_NumIndices > 0) | ||||
| 				recheckIndexes = ExecInsertIndexTuples(resultRelInfo, | ||||
| 													   slot, estate, false, | ||||
| 													   false, NULL, NIL, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user