diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2015-07-31 19:26:33 -0400 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2015-07-31 19:26:33 -0400 |
commit | edf26ed033f18bddc9bfe5c239388330150766a1 (patch) | |
tree | a2ba01856adf4c92152d2dcba273021f43611950 /src/backend/access/transam/xlog.c | |
parent | c7446194fa8fbbb9e8d948668bb47563ab58f45f (diff) |
Fix an oversight in checking whether a join with LATERAL refs is legal.
In many cases, we can implement a semijoin as a plain innerjoin by first
passing the righthand-side relation through a unique-ification step.
However, one of the cases where this does NOT work is where the RHS has
a LATERAL reference to the LHS; that makes the RHS dependent on the LHS
so that unique-ification is meaningless. joinpath.c understood this,
and so would not generate any join paths of this kind ... but join_is_legal
neglected to check for the case, so it would think that we could do it.
The upshot would be a "could not devise a query plan for the given query"
failure once we had failed to generate any join paths at all for the bogus
join pair.
Back-patch to 9.3 where LATERAL was added.
Diffstat (limited to 'src/backend/access/transam/xlog.c')
0 files changed, 0 insertions, 0 deletions