Commit d1a4db8d authored by Tom Lane's avatar Tom Lane

Improve EXPLAIN's ability to cope with LATERAL references in plans.

push_child_plan/pop_child_plan didn't bother to adjust the "ancestors"
list of parent plan nodes when descending to a child plan node.  I think
this was okay when it was written, but it's not okay in the presence of
LATERAL references, since a subplan node could easily be returning a
LATERAL value back up to the same nestloop node that provides the value.
Per changed regression test results, the omission led to failure to
interpret Param nodes that have perfectly good interpretations.
parent e1a6375d
...@@ -2312,14 +2312,8 @@ push_child_plan(deparse_namespace *dpns, PlanState *ps, ...@@ -2312,14 +2312,8 @@ push_child_plan(deparse_namespace *dpns, PlanState *ps,
/* Save state for restoration later */ /* Save state for restoration later */
*save_dpns = *dpns; *save_dpns = *dpns;
/* /* Link current plan node into ancestors list */
* Currently we don't bother to adjust the ancestors list, because an dpns->ancestors = lcons(dpns->planstate, dpns->ancestors);
* OUTER_VAR or INNER_VAR reference really shouldn't contain any Params
* that would be set by the parent node itself. If we did want to adjust
* the list, lcons'ing dpns->planstate onto dpns->ancestors would be the
* appropriate thing --- and pop_child_plan would need to undo the change
* to the list.
*/
/* Set attention on selected child */ /* Set attention on selected child */
set_deparse_planstate(dpns, ps); set_deparse_planstate(dpns, ps);
...@@ -2331,8 +2325,16 @@ push_child_plan(deparse_namespace *dpns, PlanState *ps, ...@@ -2331,8 +2325,16 @@ push_child_plan(deparse_namespace *dpns, PlanState *ps,
static void static void
pop_child_plan(deparse_namespace *dpns, deparse_namespace *save_dpns) pop_child_plan(deparse_namespace *dpns, deparse_namespace *save_dpns)
{ {
List *ancestors;
/* Get rid of ancestors list cell added by push_child_plan */
ancestors = list_delete_first(dpns->ancestors);
/* Restore fields changed by push_child_plan */ /* Restore fields changed by push_child_plan */
*dpns = *save_dpns; *dpns = *save_dpns;
/* Make sure dpns->ancestors is right (may be unnecessary) */
dpns->ancestors = ancestors;
} }
/* /*
......
...@@ -3172,7 +3172,7 @@ explain (costs off) ...@@ -3172,7 +3172,7 @@ explain (costs off)
Nested Loop Nested Loop
-> Seq Scan on int8_tbl a -> Seq Scan on int8_tbl a
-> Hash Left Join -> Hash Left Join
Hash Cond: (x.q2 = ($0)) Hash Cond: (x.q2 = (a.q1))
-> Seq Scan on int8_tbl x -> Seq Scan on int8_tbl x
-> Hash -> Hash
-> Seq Scan on int4_tbl y -> Seq Scan on int4_tbl y
......
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