• unknown's avatar
    Fix bug lp:825095 · 9e60b55f
    unknown authored
    Analysis:
    Partial matching is used even when there are no NULLs in
    a materialized subquery, as long as the left NOT IN operand
    may contain NULL values.
    
    This case was not handled correctly in two different places.
    First, the implementation of parital matching did not clear
    the set of matching columns when the merge process advanced
    to the next row.
    
    Second, there is no need to perform partial matching at all
    when the left operand has no NULLs.
    
    Solution:
    First fix subselect_rowid_merge_engine::partial_match() to
    properly cleanup the bitmap of matching keys when advancing
    to the next row.
    
    Second, change subselect_partial_match_engine::exec() so
    that when the materialized subquery doesn't contain any
    NULLs, and the left operand of [NOT] IN doesn't contain
    NULLs either, the method returns without doing any
    unnecessary partial matching. The correct result in this
    case is in Item::in_value.
    9e60b55f
subselect_mat.test 7.38 KB