Commit 655393a0 authored by Robert Haas's avatar Robert Haas

Fix parallel hash join path search.

When the very cheapest path is not parallel-safe, we want to instead use
the cheapest unparameterized path that is.  The old code searched
innerrel->cheapest_parameterized_paths, but that isn't right, because
the path we want may not be in that list.  Search innerrel->pathlist
instead.

Spotted by Dilip Kumar.

Discussion: http://postgr.es/m/CAFiTN-szCEcZrQm0i_w4xqSaRUTOUFstNu32Zn4rxxDcoa8gnA@mail.gmail.com
parent b2678efd
...@@ -1510,9 +1510,9 @@ hash_inner_and_outer(PlannerInfo *root, ...@@ -1510,9 +1510,9 @@ hash_inner_and_outer(PlannerInfo *root,
/* /*
* Normally, given that the joinrel is parallel-safe, the cheapest * Normally, given that the joinrel is parallel-safe, the cheapest
* total inner path will also be parallel-safe, but if not, we'll * total inner path will also be parallel-safe, but if not, we'll
* have to search cheapest_parameterized_paths for the cheapest * have to search for the cheapest safe, unparameterized inner
* safe, unparameterized inner path. If doing JOIN_UNIQUE_INNER, * path. If doing JOIN_UNIQUE_INNER, we can't use any alternative
* we can't use any alternative inner path. * inner path.
*/ */
if (cheapest_total_inner->parallel_safe) if (cheapest_total_inner->parallel_safe)
cheapest_safe_inner = cheapest_total_inner; cheapest_safe_inner = cheapest_total_inner;
...@@ -1520,7 +1520,7 @@ hash_inner_and_outer(PlannerInfo *root, ...@@ -1520,7 +1520,7 @@ hash_inner_and_outer(PlannerInfo *root,
{ {
ListCell *lc; ListCell *lc;
foreach(lc, innerrel->cheapest_parameterized_paths) foreach(lc, innerrel->pathlist)
{ {
Path *innerpath = (Path *) lfirst(lc); Path *innerpath = (Path *) lfirst(lc);
......
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