mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Add fast paths for cases when no serializable transactions are running.
Dan Ports
This commit is contained in:
		| @@ -2275,6 +2275,18 @@ PredicateLockTupleRowVersionLink(const Relation relation, | |||||||
| 	TransactionId oldxmin, | 	TransactionId oldxmin, | ||||||
| 				newxmin; | 				newxmin; | ||||||
|  |  | ||||||
|  | 	/* | ||||||
|  | 	 * Bail out quickly if there are no serializable transactions | ||||||
|  | 	 * running. | ||||||
|  | 	 * | ||||||
|  | 	 * It's safe to do this check without taking any additional | ||||||
|  | 	 * locks. Even if a serializable transaction starts concurrently, | ||||||
|  | 	 * we know it can't take any SIREAD locks on the modified tuple | ||||||
|  | 	 * because the caller is holding the associated buffer page lock. | ||||||
|  | 	 */ | ||||||
|  | 	if (!TransactionIdIsValid(PredXact->SxactGlobalXmin)) | ||||||
|  | 		return; | ||||||
|  |  | ||||||
| 	oldblk = ItemPointerGetBlockNumber(&(oldTuple->t_self)); | 	oldblk = ItemPointerGetBlockNumber(&(oldTuple->t_self)); | ||||||
| 	oldoff = ItemPointerGetOffsetNumber(&(oldTuple->t_self)); | 	oldoff = ItemPointerGetOffsetNumber(&(oldTuple->t_self)); | ||||||
| 	oldxmin = HeapTupleHeaderGetXmin(oldTuple->t_data); | 	oldxmin = HeapTupleHeaderGetXmin(oldTuple->t_data); | ||||||
| @@ -2633,6 +2645,15 @@ PredicateLockPageSplit(const Relation relation, const BlockNumber oldblkno, | |||||||
| 	PREDICATELOCKTARGETTAG newtargettag; | 	PREDICATELOCKTARGETTAG newtargettag; | ||||||
| 	bool		success; | 	bool		success; | ||||||
|  |  | ||||||
|  | 	/* | ||||||
|  | 	 * Bail out quickly if there are no serializable transactions | ||||||
|  | 	 * running. As with PredicateLockTupleRowVersionLink, it's safe to | ||||||
|  | 	 * check this without taking locks because the caller is holding | ||||||
|  | 	 * the buffer page lock. | ||||||
|  | 	 */ | ||||||
|  | 	if (!TransactionIdIsValid(PredXact->SxactGlobalXmin)) | ||||||
|  | 		return; | ||||||
|  |  | ||||||
| 	if (SkipSplitTracking(relation)) | 	if (SkipSplitTracking(relation)) | ||||||
| 		return; | 		return; | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user