]> granicus.if.org Git - postgresql/commit
Fix thinko in new match_join_clauses_to_index() logic.
authorTom Lane <tgl@sss.pgh.pa.us>
Tue, 28 Feb 2012 23:10:40 +0000 (18:10 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Tue, 28 Feb 2012 23:10:40 +0000 (18:10 -0500)
commit0140a11b9ba5b22e1e4807e178bca770d46c3e28
tree8a3fad77d82609258449d6a89939edc73f5a7655
parent973e9fb294dc05a384ecae7623923ae53cb81806
Fix thinko in new match_join_clauses_to_index() logic.

We don't need to constrain the other side of an indexable join clause to
not be below an outer join; an example here is

SELECT FROM t1 LEFT JOIN t2 ON t1.a = t2.b LEFT JOIN t3 ON t2.c = t3.d;

We can consider an inner indexscan on t3.d using c = d as indexqual, even
though t2.c is potentially nulled by a previous outer join.  The comparable
logic in orindxpath.c has always worked that way, but I was being overly
cautious here.
src/backend/optimizer/path/indxpath.c