mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-19 15:49:24 +03:00 
			
		
		
		
	Repair some REINDEX problems per recent discussions. The relcache is
now able to cope with assigning new relfilenode values to nailed-in-cache indexes, so they can be reindexed using the fully crash-safe method. This leaves only shared system indexes as special cases. Remove the 'index deactivation' code, since it provides no useful protection in the shared- index case. Require reindexing of shared indexes to be done in standalone mode, but remove other restrictions on REINDEX. -P (IgnoreSystemIndexes) now prevents using indexes for lookups, but does not disable index updates. It is therefore safe to allow from PGOPTIONS. Upshot: reindexing system catalogs can be done without a standalone backend for all cases except shared catalogs.
This commit is contained in:
		| @@ -8,7 +8,7 @@ | ||||
|  * | ||||
|  * | ||||
|  * IDENTIFICATION | ||||
|  *	  $Header: /cvsroot/pgsql/src/backend/executor/execUtils.c,v 1.103 2003/08/08 21:41:40 momjian Exp $ | ||||
|  *	  $Header: /cvsroot/pgsql/src/backend/executor/execUtils.c,v 1.104 2003/09/24 18:54:01 tgl Exp $ | ||||
|  * | ||||
|  *------------------------------------------------------------------------- | ||||
|  */ | ||||
| @@ -647,12 +647,9 @@ ExecOpenIndices(ResultRelInfo *resultRelInfo) | ||||
|  | ||||
| 	resultRelInfo->ri_NumIndices = 0; | ||||
|  | ||||
| 	/* checks for disabled indexes */ | ||||
| 	/* fast path if no indexes */ | ||||
| 	if (!RelationGetForm(resultRelation)->relhasindex) | ||||
| 		return; | ||||
| 	if (IsIgnoringSystemIndexes() && | ||||
| 		IsSystemRelation(resultRelation)) | ||||
| 		return; | ||||
|  | ||||
| 	/* | ||||
| 	 * Get cached list of index OIDs | ||||
|   | ||||
| @@ -8,7 +8,7 @@ | ||||
|  * | ||||
|  * | ||||
|  * IDENTIFICATION | ||||
|  *	  $Header: /cvsroot/pgsql/src/backend/executor/nodeIndexscan.c,v 1.83 2003/08/22 20:26:43 tgl Exp $ | ||||
|  *	  $Header: /cvsroot/pgsql/src/backend/executor/nodeIndexscan.c,v 1.84 2003/09/24 18:54:01 tgl Exp $ | ||||
|  * | ||||
|  *------------------------------------------------------------------------- | ||||
|  */ | ||||
| @@ -964,12 +964,6 @@ ExecInitIndexScan(IndexScan *node, EState *estate) | ||||
|  | ||||
| 	currentRelation = heap_open(reloid, AccessShareLock); | ||||
|  | ||||
| 	if (!RelationGetForm(currentRelation)->relhasindex) | ||||
| 		ereport(ERROR, | ||||
| 				(errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE), | ||||
| 				 errmsg("indexes of relation %u were deactivated", | ||||
| 						reloid))); | ||||
|  | ||||
| 	indexstate->ss.ss_currentRelation = currentRelation; | ||||
| 	indexstate->ss.ss_currentScanDesc = NULL;	/* no heap scan here */ | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user