summaryrefslogtreecommitdiff
path: root/unittest/sql
diff options
context:
space:
mode:
authorIgor Babaev <igor@askmonty.org>2020-11-10 16:02:30 -0800
committerIgor Babaev <igor@askmonty.org>2020-11-13 08:07:20 -0800
commit190e8a4c2aeb417b405756b193e135c542d46b34 (patch)
tree13089ec6e59355967259d1b996f4dc029f083dfb /unittest/sql
parent984a06db2ce2b2e3c7c5028245905417f2141cd7 (diff)
downloadmariadb-git-190e8a4c2aeb417b405756b193e135c542d46b34.tar.gz
MDEV-23619 MariaDB crash on WITH RECURSIVE UNION ALL (CTE) query
Due to a premature cleanup of the unit that specified a recursive CTE used in the second operand of union the server fell into an infinite loop in the reported test case. In other cases this premature cleanup could cause other problems. The bug is the result of a not quite correct fix for MDEV-17024. The unit that specifies a recursive CTE has to be cleaned only after the cleanup of the last external reference to this CTE. It means that cleanups of the unit triggered not by the cleanup of a external reference to the CTE must be blocked. Usage of local table chains in selects to get external references to recursive CTEs was not correct either because of possible merges of some selects. Also fixed a minor bug in st_select_lex::set_explain_type() that caused typing 'RECURSIVE UNION' instead of 'UNION' in EXPLAIN output for external references to a recursive CTE.
Diffstat (limited to 'unittest/sql')
0 files changed, 0 insertions, 0 deletions