From: Date: December 23 2008 2:43pm Subject: bzr push into mysql-6.0-bugteam branch (sergefp:2817 to 2818) List-Archive: http://lists.mysql.com/commits/62257 Message-Id: <20081223134330.F33A715A0D7@pslp2.localdomain> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7BIT 2818 Sergey Petrunia 2008-12-23 [merge] Merge mysql-5.1-bugteam -> mysql-6.0-bugteam modified: mysql-test/include/index_merge1.inc mysql-test/r/index_merge_myisam.result sql/opt_range.cc 2817 Sergey Vojtovich 2008-12-23 [merge] Merge. added: mysql-test/include/have_simple_parser.inc mysql-test/r/fulltext_plugin.result mysql-test/r/have_simple_parser.require mysql-test/t/fulltext_plugin-master.opt mysql-test/t/fulltext_plugin.test modified: mysql-test/mysql-test-run.pl sql/sql_table.cc sql/table.cc === modified file 'mysql-test/include/index_merge1.inc' --- a/mysql-test/include/index_merge1.inc 2008-10-01 16:49:59 +0000 +++ b/mysql-test/include/index_merge1.inc 2008-12-23 13:28:13 +0000 @@ -501,4 +501,30 @@ SELECT b,a from t1 WHERE (b!='c' AND b!= DROP TABLE t1; +--echo # +--echo # BUG#40974: Incorrect query results when using clause evaluated using range check +--echo # +create table t0 (a int); +insert into t0 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9); + +create table t1 (a int); +insert into t1 values (1),(2); +create table t2(a int, b int); +insert into t2 values (1,1), (2, 1000); +create table t3 (a int, b int, filler char(100), key(a), key(b)); + +insert into t3 select 1000, 1000,'filler' from t0 A, t0 B, t0 C; +insert into t3 values (1,1,'data'); +insert into t3 values (1,1,'data'); +-- echo The plan should be ALL/ALL/ALL(Range checked for each record (index map: 0x3) +explain select * from t1 +where exists (select 1 from t2, t3 + where t2.a=t1.a and (t3.a=t2.b or t3.b=t2.b or t3.b=t2.b+1)); + +select * from t1 +where exists (select 1 from t2, t3 + where t2.a=t1.a and (t3.a=t2.b or t3.b=t2.b or t3.b=t2.b+1)); + +drop table t0, t1, t2, t3; + --echo End of 5.0 tests === modified file 'mysql-test/r/index_merge_myisam.result' --- a/mysql-test/r/index_merge_myisam.result 2008-10-02 11:29:11 +0000 +++ b/mysql-test/r/index_merge_myisam.result 2008-12-23 13:41:21 +0000 @@ -529,6 +529,34 @@ b a y z DROP TABLE t1; +# +# BUG#40974: Incorrect query results when using clause evaluated using range check +# +create table t0 (a int); +insert into t0 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9); +create table t1 (a int); +insert into t1 values (1),(2); +create table t2(a int, b int); +insert into t2 values (1,1), (2, 1000); +create table t3 (a int, b int, filler char(100), key(a), key(b)); +insert into t3 select 1000, 1000,'filler' from t0 A, t0 B, t0 C; +insert into t3 values (1,1,'data'); +insert into t3 values (1,1,'data'); +The plan should be ALL/ALL/ALL(Range checked for each record (index map: 0x3) +explain select * from t1 +where exists (select 1 from t2, t3 +where t2.a=t1.a and (t3.a=t2.b or t3.b=t2.b or t3.b=t2.b+1)); +id select_type table type possible_keys key key_len ref rows Extra +1 PRIMARY t1 ALL NULL NULL NULL NULL 2 Using where +2 DEPENDENT SUBQUERY t2 ALL NULL NULL NULL NULL 2 Using where +2 DEPENDENT SUBQUERY t3 ALL a,b NULL NULL NULL 1002 Range checked for each record (index map: 0x3) +select * from t1 +where exists (select 1 from t2, t3 +where t2.a=t1.a and (t3.a=t2.b or t3.b=t2.b or t3.b=t2.b+1)); +a +1 +2 +drop table t0, t1, t2, t3; End of 5.0 tests #---------------- ROR-index_merge tests ----------------------- SET SESSION STORAGE_ENGINE = MyISAM; === modified file 'sql/opt_range.cc' --- a/sql/opt_range.cc 2008-12-10 09:02:11 +0000 +++ b/sql/opt_range.cc 2008-12-23 13:41:21 +0000 @@ -1289,6 +1289,9 @@ QUICK_INDEX_MERGE_SELECT::~QUICK_INDEX_M quick->file= NULL; quick_selects.delete_elements(); delete pk_quick_select; + /* It's ok to call the next two even if they are already deinitialized */ + end_read_record(&read_record); + free_io_cache(head); free_root(&alloc,MYF(0)); DBUG_VOID_RETURN; }