mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Push tuple limits through Gather and Gather Merge.
If we only need, say, 10 tuples in total, then we certainly don't need more than 10 tuples from any single process. Pushing down the limit lets workers exit early when possible. For Gather Merge, there is an additional benefit: a Sort immediately below the Gather Merge can be done as a bounded sort if there is an applicable limit. Robert Haas and Tom Lane Discussion: http://postgr.es/m/CA+TgmoYa3QKKrLj5rX7UvGqhH73G1Li4B-EKxrmASaca2tFu9Q@mail.gmail.com
This commit is contained in:
		| @@ -77,6 +77,7 @@ ExecInitGatherMerge(GatherMerge *node, EState *estate, int eflags) | ||||
| 	gm_state->ps.plan = (Plan *) node; | ||||
| 	gm_state->ps.state = estate; | ||||
| 	gm_state->ps.ExecProcNode = ExecGatherMerge; | ||||
| 	gm_state->tuples_needed = -1; | ||||
|  | ||||
| 	/* | ||||
| 	 * Miscellaneous initialization | ||||
| @@ -190,7 +191,8 @@ ExecGatherMerge(PlanState *pstate) | ||||
| 			if (!node->pei) | ||||
| 				node->pei = ExecInitParallelPlan(node->ps.lefttree, | ||||
| 												 estate, | ||||
| 												 gm->num_workers); | ||||
| 												 gm->num_workers, | ||||
| 												 node->tuples_needed); | ||||
|  | ||||
| 			/* Try to launch workers. */ | ||||
| 			pcxt = node->pei->pcxt; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user