diff options
author | Ole John Aske <ole.john.aske@oracle.com> | 2011-01-12 13:15:22 +0100 |
---|---|---|
committer | Ole John Aske <ole.john.aske@oracle.com> | 2011-01-12 13:15:22 +0100 |
commit | bbf40ba3c5cac76b4efd2dc177b9ffaff1ce9266 (patch) | |
tree | 7782bdc626c20ac5ddcd58feaae2c037fc921498 /mysys/my_open.c | |
parent | 2fbee31f12c1788de03495c1e35544ec4383df8a (diff) | |
download | mariadb-git-bbf40ba3c5cac76b4efd2dc177b9ffaff1ce9266.tar.gz |
Fix for bug#58818: Incorrect result for IN/ANY subquery
If the ::single_value_transformer() find an existing HAVING condition it used
to do the transformation:
1) HAVING cond -> (HAVING Cond) AND (cond_guard (Item_ref_null_helper(...))
As the AND condition in 1) is Mc'Carty evaluated, the
right side of the AND cond should be executed only if the
original 'HAVING evaluated' to true.
However, as we failed to set 'top_level' for the tranformed HAVING condition,
'abort_on_null' was FALSE after transformation. An
UNKNOWN having condition will then not terminate evaluation of the
transformed having condition, and we incorrectly continued
into the Item_ref_null_helper() part.
Diffstat (limited to 'mysys/my_open.c')
0 files changed, 0 insertions, 0 deletions