mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Don't try to use a unopened relation
Commit 4c9d0901 mistakenly introduced a call to
TransferPredicateLocksToHeapRelation() on an index relation that had
been closed a few lines above.  Moving up an index_open() call that's
below is enough to fix the problem.
Discovered by me while testing an unrelated patch.
			
			
This commit is contained in:
		| @@ -1475,6 +1475,8 @@ index_drop(Oid indexId, bool concurrent) | ||||
| 		 * conflicts with existing predicate locks, so now is the time to move | ||||
| 		 * them to the heap relation. | ||||
| 		 */ | ||||
| 		userHeapRelation = heap_open(heapId, ShareUpdateExclusiveLock); | ||||
| 		userIndexRelation = index_open(indexId, ShareUpdateExclusiveLock); | ||||
| 		TransferPredicateLocksToHeapRelation(userIndexRelation); | ||||
|  | ||||
| 		/* | ||||
| @@ -1484,9 +1486,6 @@ index_drop(Oid indexId, bool concurrent) | ||||
| 		 */ | ||||
| 		indexRelation = heap_open(IndexRelationId, RowExclusiveLock); | ||||
|  | ||||
| 		userHeapRelation = heap_open(heapId, ShareUpdateExclusiveLock); | ||||
| 		userIndexRelation = index_open(indexId, ShareUpdateExclusiveLock); | ||||
|  | ||||
| 		tuple = SearchSysCacheCopy1(INDEXRELID, | ||||
| 									ObjectIdGetDatum(indexId)); | ||||
| 		if (!HeapTupleIsValid(tuple)) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user