summaryrefslogtreecommitdiff
path: root/contrib/btree_gist/expected
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2010-05-28 01:14:11 +0000
committerTom Lane <tgl@sss.pgh.pa.us>2010-05-28 01:14:11 +0000
commit813cd7cb1f229ca83bb9535807e917fc326d92f1 (patch)
tree0db779f3d37d2dd7266482a1b4f2c7dafebee6c2 /contrib/btree_gist/expected
parent1fa43c594fd17f46e9aeb54a98d761feb47bf2f5 (diff)
Rejigger mergejoin logic so that a tuple with a null in the first merge column
is treated like end-of-input, if nulls sort last in that column and we are not doing outer-join filling for that input. In such a case, the tuple cannot join to anything from the other input (because we assume mergejoinable operators are strict), and neither can any tuple following it in the sort order. If we're not interested in doing outer-join filling we can just pretend the tuple and its successors aren't there at all. This can save a great deal of time in situations where there are many nulls in the join column, as in a recent example from Scott Marlowe. Also, since the planner tends to not count nulls in its mergejoin scan selectivity estimates, this is an important fix to make the runtime behavior more like the estimate. I regard this as an omission in the patch I wrote years ago to teach mergejoin that tuples containing nulls aren't joinable, so I'm back-patching it. But only to 8.3 --- in older versions, we didn't have a solid notion of whether nulls sort high or low, so attempting to apply this optimization could break things.
Diffstat (limited to 'contrib/btree_gist/expected')
0 files changed, 0 insertions, 0 deletions