# Author: Horst Hunger # Created: 2010-07-13 --source include/have_partition.inc let $engine_table= MYISAM; let $engine_part= MYISAM; let $engine_subpart= MYISAM; use test; --disable_result_log --disable_query_log --disable_warnings DROP TABLE IF EXISTS t_10; DROP TABLE IF EXISTS t_100; DROP TABLE IF EXISTS t_1000; DROP TABLE IF EXISTS tp; DROP TABLE IF EXISTS tsp; DROP TABLE IF EXISTS t_empty; DROP TABLE IF EXISTS t_null; --enable_warnings eval CREATE TABLE t_10 (a INT, b VARCHAR(55), PRIMARY KEY (a)) CHECKSUM= 1, ENGINE = $engine_table; eval CREATE TABLE t_100 (a INT, b VARCHAR(55), PRIMARY KEY (a)) COMMENT= 'comment', ROW_FORMAT= COMPRESSED, ENGINE = $engine_table; eval CREATE TABLE t_1000 (a INT, b VARCHAR(55), PRIMARY KEY (a)) MIN_ROWS= 1, MAX_ROWS= 200, ENGINE = $engine_table; eval CREATE TABLE t_empty (a INT, b VARCHAR(55), PRIMARY KEY (a)) ENGINE = $engine_table; eval CREATE TABLE t_null (a INT, b VARCHAR(55), PRIMARY KEY (a)) ENGINE = $engine_table; eval CREATE TABLE tp (a INT, b VARCHAR(55), PRIMARY KEY (a)) ENGINE = $engine_part PARTITION BY RANGE (a) (PARTITION p0 VALUES LESS THAN (10), PARTITION p1 VALUES LESS THAN (100), PARTITION p2 VALUES LESS THAN (1000)); eval CREATE TABLE tsp (a INT, b VARCHAR(55), PRIMARY KEY (a)) ENGINE = $engine_subpart PARTITION BY RANGE (a) SUBPARTITION BY HASH(a) (PARTITION p0 VALUES LESS THAN (10) (SUBPARTITION sp00, SUBPARTITION sp01, SUBPARTITION sp02, SUBPARTITION sp03, SUBPARTITION sp04), PARTITION p1 VALUES LESS THAN (100) (SUBPARTITION sp10, SUBPARTITION sp11, SUBPARTITION sp12, SUBPARTITION sp13, SUBPARTITION sp14), PARTITION p2 VALUES LESS THAN (1000) (SUBPARTITION sp20, SUBPARTITION sp21, SUBPARTITION sp22, SUBPARTITION sp23, SUBPARTITION sp24)); # Values t_10 (not partitioned) INSERT INTO t_10 VALUES (1, "One"), (3, "Three"), (5, "Five"), (9, "Nine"); # Values t_100 (not partitioned) INSERT INTO t_100 VALUES (11, "Eleven"), (13, "Thirdteen"), (15, "Fifeteen"), (19, "Nineteen"); INSERT INTO t_100 VALUES (91, "Ninety-one"), (93, "Ninety-three"), (95, "Ninety-five"), (99, "Ninety-nine"); # Values t_1000 (not partitioned) INSERT INTO t_1000 VALUES (111, "Hundred elven"), (113, "Hundred thirdteen"), (115, "Hundred fiveteen"), (119, "Hundred nineteen"); INSERT INTO t_1000 VALUES (131, "Hundred thirty-one"), (133, "Hundred thirty-three"), (135, "Hundred thirty-five"), (139, "Hundred thirty-nine"); INSERT INTO t_1000 VALUES (151, "Hundred fifty-one"), (153, "Hundred fifty-three"), (155, "Hundred fity-five"), (159, "Hundred fifty-nine"); INSERT INTO t_1000 VALUES (191, "Hundred ninety-one"), (193, "Hundred ninety-three"), (195, "Hundred ninety-five"), (199, "Hundred ninety-nine"); # Values t_null (not partitioned) INSERT INTO t_null VALUES (1, "NULL"); # Values tp (partitions) INSERT INTO tp VALUES (2, "Two"), (4, "Four"), (6, "Six"), (8, "Eight"); INSERT INTO tp VALUES (12, "twelve"), (14, "Fourteen"), (16, "Sixteen"), (18, "Eightteen"); INSERT INTO tp VALUES (112, "Hundred twelve"), (114, "Hundred fourteen"), (116, "Hundred sixteen"), (118, "Hundred eightteen"); INSERT INTO tp VALUES (122, "Hundred twenty-two"), (124, "Hundred twenty-four"), (126, "Hundred twenty-six"), (128, "Hundred twenty-eight"); INSERT INTO tp VALUES (162, "Hundred sixty-two"), (164, "Hundred sixty-four"), (166, "Hundred sixty-six"), (168, "Hundred sixty-eight"); INSERT INTO tp VALUES (182, "Hundred eighty-two"), (184, "Hundred eighty-four"), (186, "Hundred eighty-six"), (188, "Hundred eighty-eight"); # Values tps (subpartitions) INSERT INTO tsp VALUES (2, "Two"), (4, "Four"), (6, "Six"), (8, "Eight"); INSERT INTO tsp VALUES (12, "twelve"), (14, "Fourteen"), (16, "Sixteen"), (18, "Eightteen"); INSERT INTO tsp VALUES (112, "Hundred twelve"), (114, "Hundred fourteen"), (116, "Hundred sixteen"), (118, "Hundred eightteen"); INSERT INTO tsp VALUES (122, "Hundred twenty-two"), (124, "Hundred twenty-four"), (126, "Hundred twenty-six"), (128, "Hundred twenty-eight"); INSERT INTO tsp VALUES (162, "Hundred sixty-two"), (164, "Hundred sixty-four"), (166, "Hundred sixty-six"), (168, "Hundred sixty-eight"); INSERT INTO tsp VALUES (182, "Hundred eight-two"), (184, "Hundred eighty-four"), (186, "Hundred eighty-six"), (188, "Hundred eighty-eight"); eval CREATE TABLE tsp_01(a INT,b VARCHAR(55),PRIMARY KEY (a)) ENGINE = $engine_table AS SELECT a, b FROM t_10 WHERE MOD(a,5)= 1; eval CREATE TABLE tsp_02(a INT,b VARCHAR(55),PRIMARY KEY (a)) ENGINE = $engine_table AS SELECT a, b FROM t_10 WHERE MOD(a,5)= 2; eval CREATE TABLE tsp_03(a INT,b VARCHAR(55),PRIMARY KEY (a)) ENGINE = $engine_table AS SELECT a, b FROM t_10 WHERE MOD(a,5)= 3; eval CREATE TABLE tsp_04(a INT,b VARCHAR(55),PRIMARY KEY (a)) ENGINE = $engine_table AS SELECT a, b FROM t_10 WHERE MOD(a,5)= 4; eval CREATE TABLE tsp_00(a INT,b VARCHAR(55),PRIMARY KEY (a)) ENGINE = $engine_table AS SELECT a, b FROM t_10 WHERE MOD(a,5)= 0; SHOW CREATE TABLE t_10; SHOW CREATE TABLE t_100; SHOW CREATE TABLE t_1000; SHOW CREATE TABLE tp; SHOW CREATE TABLE tsp; --enable_result_log --enable_query_log --sorted_result SELECT * FROM t_10; --sorted_result SELECT * FROM t_100; --sorted_result SELECT * FROM t_1000; --sorted_result SELECT * FROM tp; --sorted_result SELECT * FROM tsp; --sorted_result SELECT * FROM tsp_00; --sorted_result SELECT * FROM tsp_01; --sorted_result SELECT * FROM tsp_02; --sorted_result SELECT * FROM tsp_03; --sorted_result SELECT * FROM tsp_04; # 13) Exchanges with different table options. # IGNORE was removed in bug#57708. --error ER_TABLES_DIFFERENT_METADATA ALTER TABLE tp EXCHANGE PARTITION p0 WITH TABLE t_10; #--error ER_TABLES_DIFFERENT_METADATA #ALTER TABLE tp EXCHANGE PARTITION p0 WITH TABLE t_10 IGNORE; SELECT TABLE_NAME, ROW_FORMAT FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = 'test' AND TABLE_NAME IN ('tp', 't_100'); ALTER TABLE tp EXCHANGE PARTITION p1 WITH TABLE t_100; #--error ER_TABLES_DIFFERENT_METADATA #ALTER TABLE tp EXCHANGE PARTITION p1 WITH TABLE t_100 IGNORE; --error ER_PARTITION_EXCHANGE_DIFFERENT_OPTION ALTER TABLE tp EXCHANGE PARTITION p1 WITH TABLE t_1000; #--error ER_PARTITION_EXCHANGE_DIFFERENT_OPTION #ALTER TABLE tp EXCHANGE PARTITION p1 WITH TABLE t_1000 IGNORE; --source suite/parts/inc/part_exch_drop_tabs.inc