mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 04:22:27 +01:00
202 lines
7.8 KiB
SQL
202 lines
7.8 KiB
SQL
# Author: Horst Hunger
|
|
# Created: 2010-07-13
|
|
|
|
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',
|
|
ENGINE = $engine_table;
|
|
|
|
eval CREATE TABLE t_1000 (a INT, b VARCHAR(55), PRIMARY KEY (a))
|
|
MIN_ROWS= 1,
|
|
MAX_ROWS= 2000,
|
|
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))
|
|
CHECKSUM= 1,
|
|
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 tp1 (a INT, b VARCHAR(55), PRIMARY KEY (a))
|
|
ENGINE = $engine_part
|
|
PARTITION BY RANGE (a)
|
|
(PARTITION p0 VALUES LESS THAN (10) MAX_ROWS=2000 MIN_ROWS=1,
|
|
PARTITION p1 VALUES LESS THAN (100) MAX_ROWS=2000 MIN_ROWS=1,
|
|
PARTITION p2 VALUES LESS THAN (1000) MAX_ROWS=2000 MIN_ROWS=1
|
|
);
|
|
|
|
eval CREATE TABLE tsp (a INT,
|
|
b VARCHAR(55),
|
|
PRIMARY KEY (a))
|
|
COMMENT= 'comment',
|
|
ENGINE = $engine_subpart
|
|
PARTITION BY RANGE (a)
|
|
SUBPARTITION BY HASH(a)
|
|
(PARTITION p0 VALUES LESS THAN (10)
|
|
(SUBPARTITION sp00 MAX_ROWS=2000 MIN_ROWS=1,
|
|
SUBPARTITION sp01 MAX_ROWS=2000 MIN_ROWS=1,
|
|
SUBPARTITION sp02 MAX_ROWS=2000 MIN_ROWS=1,
|
|
SUBPARTITION sp03 MAX_ROWS=2000 MIN_ROWS=1,
|
|
SUBPARTITION sp04 MAX_ROWS=2000 MIN_ROWS=1),
|
|
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 tp1 (partitions)
|
|
INSERT INTO tp1 VALUES (2, "Two"), (4, "Four"), (6, "Six"), (8, "Eight");
|
|
INSERT INTO tp1 VALUES (12, "twelve"), (14, "Fourteen"), (16, "Sixteen"), (18, "Eightteen");
|
|
INSERT INTO tp1 VALUES (112, "Hundred twelve"), (114, "Hundred fourteen"), (116, "Hundred sixteen"), (118, "Hundred eightteen");
|
|
INSERT INTO tp1 VALUES (122, "Hundred twenty-two"), (124, "Hundred twenty-four"), (126, "Hundred twenty-six"), (128, "Hundred twenty-eight");
|
|
INSERT INTO tp1 VALUES (162, "Hundred sixty-two"), (164, "Hundred sixty-four"), (166, "Hundred sixty-six"), (168, "Hundred sixty-eight");
|
|
INSERT INTO tp1 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,
|
|
MAX_ROWS=2000, MIN_ROWS=1
|
|
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_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.
|
|
# See bug#55944 to change the IGNORE
|
|
# IGNORE was removed in bug#57708.
|
|
INSERT INTO t_10 VALUES (10, "TEN");
|
|
--error ER_ROW_DOES_NOT_MATCH_PARTITION
|
|
ALTER TABLE tp EXCHANGE PARTITION p0 WITH TABLE t_10;
|
|
--sorted_result
|
|
SELECT * FROM tp WHERE a < 11;
|
|
--sorted_result
|
|
SELECT * FROM t_10 WHERE a < 11;
|
|
#ALTER TABLE tp EXCHANGE PARTITION p0 WITH TABLE t_10 IGNORE;
|
|
#--sorted_result
|
|
#SELECT * FROM tp WHERE a < 11;
|
|
#--sorted_result
|
|
#SELECT * FROM t_10 WHERE a < 11;
|
|
INSERT INTO t_1000 VALUES (99, "Ninetynine");
|
|
--error ER_ROW_DOES_NOT_MATCH_PARTITION
|
|
ALTER TABLE tp1 EXCHANGE PARTITION p2 WITH TABLE t_1000;
|
|
--sorted_result
|
|
SELECT * FROM tp1 WHERE a < 1000 AND a > 98;
|
|
--sorted_result
|
|
SELECT * FROM t_1000 WHERE a < 1000 AND a > 98;
|
|
#ALTER TABLE tp1 EXCHANGE PARTITION p2 WITH TABLE t_1000 IGNORE;
|
|
#--sorted_result
|
|
#SELECT * FROM tp1 WHERE a < 1000 AND a > 98;
|
|
#--sorted_result
|
|
#SELECT * FROM t_1000 WHERE a < 1000 AND a > 98;
|
|
INSERT INTO tsp_03 VALUES (20, "Twenty");
|
|
--error ER_ROW_DOES_NOT_MATCH_PARTITION
|
|
ALTER TABLE tsp EXCHANGE PARTITION sp03 WITH TABLE tsp_03;
|
|
--sorted_result
|
|
SELECT * FROM tsp;
|
|
--sorted_result
|
|
SELECT * FROM tsp_03;
|
|
#ALTER TABLE tsp EXCHANGE PARTITION sp03 WITH TABLE tsp_03 IGNORE;
|
|
#--sorted_result
|
|
#SELECT * FROM tsp;
|
|
#--sorted_result
|
|
#SELECT * FROM tsp_03;
|
|
|
|
DROP TABLE tp1;
|
|
--source suite/parts/inc/part_exch_drop_tabs.inc
|
|
|