mirror of
https://github.com/MariaDB/server.git
synced 2025-01-25 00:04:33 +01:00
05617af025
MERGE engine". Backport the patch from 6.0 by Ingo Struewing: revid:ingo.struewing@sun.com-20091028183659-6kmv1k3gdq6cpg4d Bug#36171 - CREATE TEMPORARY TABLE and MERGE engine In former MySQL versions, up to 5.1.23/6.0.4 it was possible to create temporary MERGE tables with non-temporary MyISAM tables. This has been changed in the mentioned version due to Bug 19627 (temporary merge table locking). MERGE children were locked through the parent table. If the parent was temporary, it was not locked and so the children were not locked either. Parallel use of the MyISAM tables corrupted them. Since 6.0.6 (WL 4144 - Lock MERGE engine children), the children are locked independently from the parent. Now it is possible to allow non-temporary children with a temporary parent. Even though the temporary MERGE table itself is not locked, each non-temporary MyISAM table is locked anyway. NOTE: Behavior change: In 5.1.23/6.0.4 we prohibited non-temporary children with a temporary MERGE table. Now we re-allow it. An important side-effect is that temporary tables, which overlay non-temporary MERGE children, overlay the children in the MERGE table. mysql-test/r/merge.result: Update results (Bug#36171). mysql-test/r/merge_mmap.result: Update results (Bug#36171). mysql-test/t/merge.test: Add tests for Bug#36171 mysql-test/t/merge_mmap.test: Add tests for Bug#36171. storage/myisammrg/ha_myisammrg.cc: Changed constraint for temporary state of tables.
151 lines
4 KiB
Text
151 lines
4 KiB
Text
#
|
|
# Test of MERGE TABLES with MyISAM memory mapping enabled (--myisam-use-mmap)
|
|
#
|
|
|
|
# MERGE tables require MyISAM tables
|
|
--let $default=`SELECT @@global.storage_engine`
|
|
SET GLOBAL storage_engine = MyISAM;
|
|
SET SESSION storage_engine = MyISAM;
|
|
|
|
# Clean up resources used in this test case.
|
|
--disable_warnings
|
|
DROP TABLE IF EXISTS t1, t2, m1, m2;
|
|
--enable_warnings
|
|
|
|
####################
|
|
## No locked tables.
|
|
####################
|
|
#
|
|
# INSERT-SELECT with no TEMPORARY table.
|
|
#
|
|
CREATE TABLE t1 (c1 INT);
|
|
CREATE TABLE t2 (c1 INT);
|
|
CREATE TABLE m1 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
CREATE TABLE m2 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
INSERT INTO t1 VALUES (1);
|
|
INSERT INTO t2 VALUES (2), (3), (4);
|
|
INSERT INTO m2 SELECT * FROM m1;
|
|
SELECT * FROM m2;
|
|
SELECT * FROM t2;
|
|
DROP TABLE m2, m1, t2, t1;
|
|
#
|
|
# INSERT-SELECT with TEMPORARY select table.
|
|
#
|
|
CREATE TABLE t1 (c1 INT);
|
|
CREATE TABLE t2 (c1 INT);
|
|
CREATE TEMPORARY TABLE m1 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
CREATE TABLE m2 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
INSERT INTO t1 VALUES (1);
|
|
INSERT INTO t2 VALUES (2), (3), (4);
|
|
INSERT INTO m2 SELECT * FROM m1;
|
|
SELECT * FROM m2;
|
|
DROP TABLE m2, m1, t2, t1;
|
|
#
|
|
# INSERT-SELECT with TEMPORARY insert table.
|
|
#
|
|
CREATE TABLE t1 (c1 INT);
|
|
CREATE TABLE t2 (c1 INT);
|
|
CREATE TABLE m1 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
CREATE TEMPORARY TABLE m2 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
INSERT INTO t1 VALUES (1);
|
|
INSERT INTO t2 VALUES (2), (3), (4);
|
|
INSERT INTO m2 SELECT * FROM m1;
|
|
SELECT * FROM m2;
|
|
DROP TABLE m2, m1, t2, t1;
|
|
#
|
|
# INSERT-SELECT with TEMPORARY both tables.
|
|
#
|
|
CREATE TABLE t1 (c1 INT);
|
|
CREATE TABLE t2 (c1 INT);
|
|
CREATE TEMPORARY TABLE m1 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
CREATE TEMPORARY TABLE m2 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
INSERT INTO t1 VALUES (1);
|
|
INSERT INTO t2 VALUES (2), (3), (4);
|
|
INSERT INTO m2 SELECT * FROM m1;
|
|
SELECT * FROM m2;
|
|
DROP TABLE m2, m1, t2, t1;
|
|
|
|
####################
|
|
## With LOCK TABLES.
|
|
####################
|
|
#
|
|
# INSERT-SELECT with no TEMPORARY table.
|
|
#
|
|
CREATE TABLE t1 (c1 INT);
|
|
CREATE TABLE t2 (c1 INT);
|
|
CREATE TABLE m1 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
CREATE TABLE m2 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
LOCK TABLE m1 WRITE, m2 WRITE;
|
|
INSERT INTO t1 VALUES (1);
|
|
INSERT INTO t2 VALUES (2), (3), (4);
|
|
INSERT INTO m2 SELECT * FROM m1;
|
|
SELECT * FROM m2;
|
|
SELECT * FROM t2;
|
|
UNLOCK TABLES;
|
|
DROP TABLE m2, m1, t2, t1;
|
|
#
|
|
# INSERT-SELECT with TEMPORARY select table.
|
|
#
|
|
CREATE TABLE t1 (c1 INT);
|
|
CREATE TABLE t2 (c1 INT);
|
|
CREATE TEMPORARY TABLE m1 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
CREATE TABLE m2 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
LOCK TABLE m1 WRITE, m2 WRITE;
|
|
INSERT INTO t1 VALUES (1);
|
|
INSERT INTO t2 VALUES (2), (3), (4);
|
|
INSERT INTO m2 SELECT * FROM m1;
|
|
SELECT * FROM m2;
|
|
UNLOCK TABLES;
|
|
DROP TABLE m2, m1, t2, t1;
|
|
#
|
|
# INSERT-SELECT with TEMPORARY insert table.
|
|
#
|
|
CREATE TABLE t1 (c1 INT);
|
|
CREATE TABLE t2 (c1 INT);
|
|
CREATE TABLE m1 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
CREATE TEMPORARY TABLE m2 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
LOCK TABLE m1 WRITE, m2 WRITE;
|
|
INSERT INTO t1 VALUES (1);
|
|
INSERT INTO t2 VALUES (2), (3), (4);
|
|
INSERT INTO m2 SELECT * FROM m1;
|
|
SELECT * FROM m2;
|
|
UNLOCK TABLES;
|
|
DROP TABLE m2, m1, t2, t1;
|
|
#
|
|
# INSERT-SELECT with TEMPORARY both tables.
|
|
#
|
|
CREATE TABLE t1 (c1 INT);
|
|
CREATE TABLE t2 (c1 INT);
|
|
CREATE TEMPORARY TABLE m1 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
CREATE TEMPORARY TABLE m2 (c1 INT) ENGINE=MRG_MyISAM UNION=(t1,t2)
|
|
INSERT_METHOD=LAST;
|
|
LOCK TABLE m1 WRITE, m2 WRITE;
|
|
INSERT INTO t1 VALUES (1);
|
|
INSERT INTO t2 VALUES (2), (3), (4);
|
|
INSERT INTO m2 SELECT * FROM m1;
|
|
SELECT * FROM m2;
|
|
UNLOCK TABLES;
|
|
DROP TABLE m2, m1, t2, t1;
|
|
|
|
--echo End of 6.0 tests
|
|
|
|
--disable_result_log
|
|
--disable_query_log
|
|
eval SET GLOBAL storage_engine = $default;
|
|
--enable_result_log
|
|
--enable_query_log
|