Commit 1ea60ad6 authored by Robert Haas's avatar Robert Haas

Fix failure to use clamp_row_est() for parallel joins.

Commit 0c2070ce neglected to use
clamp_row_est() where it should have done so.

Patch by me.  Report by Amit Kapila.

Discussion: http://postgr.es/m/CAA4eK1KPm8RYa1Kun3ZmQj9pb723b-EFN70j47Pid1vn3ByquA@mail.gmail.com
parent c5832346
...@@ -2147,7 +2147,12 @@ final_cost_nestloop(PlannerInfo *root, NestPath *path, ...@@ -2147,7 +2147,12 @@ final_cost_nestloop(PlannerInfo *root, NestPath *path,
/* For partial paths, scale row estimate. */ /* For partial paths, scale row estimate. */
if (path->path.parallel_workers > 0) if (path->path.parallel_workers > 0)
path->path.rows /= get_parallel_divisor(&path->path); {
double parallel_divisor = get_parallel_divisor(&path->path);
path->path.rows =
clamp_row_est(path->path.rows / parallel_divisor);
}
/* /*
* We could include disable_cost in the preliminary estimate, but that * We could include disable_cost in the preliminary estimate, but that
...@@ -2569,7 +2574,12 @@ final_cost_mergejoin(PlannerInfo *root, MergePath *path, ...@@ -2569,7 +2574,12 @@ final_cost_mergejoin(PlannerInfo *root, MergePath *path,
/* For partial paths, scale row estimate. */ /* For partial paths, scale row estimate. */
if (path->jpath.path.parallel_workers > 0) if (path->jpath.path.parallel_workers > 0)
path->jpath.path.rows /= get_parallel_divisor(&path->jpath.path); {
double parallel_divisor = get_parallel_divisor(&path->jpath.path);
path->jpath.path.rows =
clamp_row_est(path->jpath.path.rows / parallel_divisor);
}
/* /*
* We could include disable_cost in the preliminary estimate, but that * We could include disable_cost in the preliminary estimate, but that
...@@ -2952,7 +2962,12 @@ final_cost_hashjoin(PlannerInfo *root, HashPath *path, ...@@ -2952,7 +2962,12 @@ final_cost_hashjoin(PlannerInfo *root, HashPath *path,
/* For partial paths, scale row estimate. */ /* For partial paths, scale row estimate. */
if (path->jpath.path.parallel_workers > 0) if (path->jpath.path.parallel_workers > 0)
path->jpath.path.rows /= get_parallel_divisor(&path->jpath.path); {
double parallel_divisor = get_parallel_divisor(&path->jpath.path);
path->jpath.path.rows =
clamp_row_est(path->jpath.path.rows / parallel_divisor);
}
/* /*
* We could include disable_cost in the preliminary estimate, but that * We could include disable_cost in the preliminary estimate, but that
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment