mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Reuse BrinDesc and BrinRevmap in brininsert
The brininsert code used to initialize (and destroy) BrinDesc and BrinRevmap for each tuple, which is not free. This patch initializes these structures only once, and reuses them for all inserts in the same command. The data is passed through indexInfo->ii_AmCache. This also introduces an optional AM callback "aminsertcleanup" that allows performing custom cleanup in case simply pfree-ing ii_AmCache is not sufficient (which is the case when the cache contains TupleDesc, Buffers, and so on). Author: Soumyadeep Chakraborty Reviewed-by: Alvaro Herrera, Matthias van de Meent, Tomas Vondra Discussion: https://postgr.es/m/CAE-ML%2B9r2%3DaO1wwji1sBN9gvPz2xRAtFUGfnffpd0ZqyuzjamA%40mail.gmail.com
This commit is contained in:
		| @@ -233,15 +233,20 @@ ExecCloseIndices(ResultRelInfo *resultRelInfo) | ||||
| 	int			i; | ||||
| 	int			numIndices; | ||||
| 	RelationPtr indexDescs; | ||||
| 	IndexInfo **indexInfos; | ||||
|  | ||||
| 	numIndices = resultRelInfo->ri_NumIndices; | ||||
| 	indexDescs = resultRelInfo->ri_IndexRelationDescs; | ||||
| 	indexInfos = resultRelInfo->ri_IndexRelationInfo; | ||||
|  | ||||
| 	for (i = 0; i < numIndices; i++) | ||||
| 	{ | ||||
| 		if (indexDescs[i] == NULL) | ||||
| 			continue;			/* shouldn't happen? */ | ||||
|  | ||||
| 		/* Give the index a chance to do some post-insert cleanup */ | ||||
| 		index_insert_cleanup(indexDescs[i], indexInfos[i]); | ||||
|  | ||||
| 		/* Drop lock acquired by ExecOpenIndices */ | ||||
| 		index_close(indexDescs[i], RowExclusiveLock); | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user