• Tom Lane's avatar
    Fix bug introduced into mergejoin logic by performance improvement patch of · b3358e26
    Tom Lane authored
    2005-05-13.  When we find that a new inner tuple can't possibly match any
    outer tuple (because it contains a NULL), we can't immediately skip the
    tuple when we are in NEXTINNER state.  Doing so can lead to emitting
    multiple copies of the tuple in FillInner mode, because we may rescan the
    tuple after returning to a previous marked tuple.  Instead, proceed to
    NEXTOUTER state the same as we used to do.  After we've found that there's
    no need to return to the marked position, we can go to SKIPINNER_ADVANCE
    state instead of SKIP_TEST when the inner tuple is unmatchable; this
    preserves the performance improvement.  Per bug report from Bruce.
    I also made a couple of cosmetic code rearrangements and added a regression
    test for the problem.
    b3358e26
join.sql 9.21 KB