mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Add support for REFRESH MATERIALIZED VIEW CONCURRENTLY.
This allows reads to continue without any blocking while a REFRESH
runs.  The new data appears atomically as part of transaction
commit.
Review questioned the Assert that a matview was not a system
relation.  This will be addressed separately.
Reviewed by Hitoshi Harada, Robert Haas, Andres Freund.
Merged after review with security patch f3ab5d4.
			
			
This commit is contained in:
		| @@ -42,6 +42,7 @@ | ||||
| #include "access/transam.h" | ||||
| #include "access/xact.h" | ||||
| #include "catalog/namespace.h" | ||||
| #include "commands/matview.h" | ||||
| #include "commands/trigger.h" | ||||
| #include "executor/execdebug.h" | ||||
| #include "foreign/fdwapi.h" | ||||
| @@ -999,10 +1000,11 @@ CheckValidResultRel(Relation resultRel, CmdType operation) | ||||
| 			} | ||||
| 			break; | ||||
| 		case RELKIND_MATVIEW: | ||||
| 			ereport(ERROR, | ||||
| 					(errcode(ERRCODE_WRONG_OBJECT_TYPE), | ||||
| 					 errmsg("cannot change materialized view \"%s\"", | ||||
| 							RelationGetRelationName(resultRel)))); | ||||
| 			if (!MatViewIncrementalMaintenanceIsEnabled()) | ||||
| 				ereport(ERROR, | ||||
| 						(errcode(ERRCODE_WRONG_OBJECT_TYPE), | ||||
| 						 errmsg("cannot change materialized view \"%s\"", | ||||
| 								RelationGetRelationName(resultRel)))); | ||||
| 			break; | ||||
| 		case RELKIND_FOREIGN_TABLE: | ||||
| 			/* Okay only if the FDW supports it */ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user