From: Oystein Grovlen Date: November 10 2010 3:09pm Subject: bzr push into mysql-5.5-bugteam branch (oystein.grovlen:3113 to 3114) Bug#57704 List-Archive: http://lists.mysql.com/commits/123439 X-Bug: 57704 MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit 3114 Oystein Grovlen 2010-11-10 Bug#57704 Cleanup code dies with void TABLE::set_keyread(bool): Assertion `file' failed. This bug was introduced in this revision: kostja@stripped ("A pre-requisite patch for the fix for Bug#52044.") It happens because close_thread_tables() is now called in open_and_lock_tables upon failure. Hence, table is no longer open when optimizer tries to do cleanup. Fix: Make sure to do cleanup in st_select_lex_unit::prepare() upon failure. This way, cleanup() is called before tables are released. @ mysql-test/r/subselect.result Added test case for Bug#57704. @ mysql-test/t/subselect.test Added test case for Bug#57704. @ sql/sql_union.cc st_select_lex_unit::prepare(): On failure, make sure cleanup() is called. modified: mysql-test/r/subselect.result mysql-test/t/subselect.test sql/sql_union.cc 3113 Dmitry Shulga 2010-11-10 [merge] null merge. === modified file 'mysql-test/r/subselect.result' --- a/mysql-test/r/subselect.result 2010-09-09 15:00:33 +0000 +++ b/mysql-test/r/subselect.result 2010-11-10 14:48:29 +0000 @@ -5005,3 +5005,15 @@ SELECT * FROM t2 UNION SELECT * FROM t2 ORDER BY (SELECT * FROM t1 WHERE MATCH(a) AGAINST ('+abc' IN BOOLEAN MODE)); DROP TABLE t1,t2; End of 5.1 tests +# +# Bug #57704: Cleanup code dies with void TABLE::set_keyread(bool): +# Assertion `file' failed. +# +CREATE TABLE t1 (a INT); +SELECT 1 FROM +(SELECT ROW( +(SELECT 1 FROM t1 RIGHT JOIN +(SELECT 1 FROM t1, t1 t2) AS d ON 1), +1) FROM t1) AS e; +ERROR 21000: Operand should contain 1 column(s) +DROP TABLE t1; === modified file 'mysql-test/t/subselect.test' --- a/mysql-test/t/subselect.test 2010-06-25 13:32:47 +0000 +++ b/mysql-test/t/subselect.test 2010-11-10 14:48:29 +0000 @@ -3946,3 +3946,21 @@ DROP TABLE t1,t2; --enable_result_log --echo End of 5.1 tests + +--echo # +--echo # Bug #57704: Cleanup code dies with void TABLE::set_keyread(bool): +--echo # Assertion `file' failed. +--echo # + +CREATE TABLE t1 (a INT); + +--error ER_OPERAND_COLUMNS +SELECT 1 FROM + (SELECT ROW( + (SELECT 1 FROM t1 RIGHT JOIN + (SELECT 1 FROM t1, t1 t2) AS d ON 1), + 1) FROM t1) AS e; + +DROP TABLE t1; + + === modified file 'sql/sql_union.cc' --- a/sql/sql_union.cc 2010-10-20 19:02:59 +0000 +++ b/sql/sql_union.cc 2010-11-10 14:48:29 +0000 @@ -434,6 +434,7 @@ bool st_select_lex_unit::prepare(THD *th err: thd_arg->lex->current_select= lex_select_save; + (void) cleanup(); DBUG_RETURN(TRUE); } No bundle (reason: useless for push emails).