mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Rearrange snapshot handling to make rule expansion more consistent.
With this patch, portals, SQL functions, and SPI all agree that there should be only a CommandCounterIncrement between the queries that are generated from a single SQL command by rule expansion. Fetching a whole new snapshot now happens only between original queries. This is equivalent to the existing behavior of EXPLAIN ANALYZE, and it was judged to be the best choice since it eliminates one source of concurrency hazards for rules. The patch should also make things marginally faster by reducing the number of snapshot push/pop operations. The patch removes pg_parse_and_rewrite(), which is no longer used anywhere. There was considerable discussion about more aggressive refactoring of the query-processing functions exported by postgres.c, but for the moment nothing more has been done there. I also took the opportunity to refactor snapmgr.c's API slightly: the former PushUpdatedSnapshot() has been split into two functions. Marko Tiikkaja, reviewed by Steve Singer and Tom Lane
This commit is contained in:
		| @@ -1216,7 +1216,8 @@ BeginCopy(bool is_from, | ||||
| 		 * Use a snapshot with an updated command ID to ensure this query sees | ||||
| 		 * results of any previously executed queries. | ||||
| 		 */ | ||||
| 		PushUpdatedSnapshot(GetActiveSnapshot()); | ||||
| 		PushCopiedSnapshot(GetActiveSnapshot()); | ||||
| 		UpdateActiveSnapshotCommandId(); | ||||
|  | ||||
| 		/* Create dest receiver for COPY OUT */ | ||||
| 		dest = CreateDestReceiver(DestCopyOut); | ||||
|   | ||||
| @@ -366,7 +366,8 @@ ExplainOnePlan(PlannedStmt *plannedstmt, ExplainState *es, | ||||
| 	 * Use a snapshot with an updated command ID to ensure this query sees | ||||
| 	 * results of any previously executed queries. | ||||
| 	 */ | ||||
| 	PushUpdatedSnapshot(GetActiveSnapshot()); | ||||
| 	PushCopiedSnapshot(GetActiveSnapshot()); | ||||
| 	UpdateActiveSnapshotCommandId(); | ||||
|  | ||||
| 	/* Create a QueryDesc requesting no output */ | ||||
| 	queryDesc = CreateQueryDesc(plannedstmt, queryString, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user