mirror of
https://github.com/MariaDB/server.git
synced 2025-01-26 00:34:18 +01:00
19d24f011c
Fixed partition pruning for NULL value.
1235 lines
29 KiB
Text
1235 lines
29 KiB
Text
create table t1 (a int, b int)
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p2 VALUES IN (4,5,6),
|
|
PARTITION p1 VALUES IN (1)
|
|
)
|
|
;
|
|
insert into t1 values (10,10);
|
|
ERROR HY000: Table has no partition for value 10
|
|
drop table t1;
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p2 VALUES IN (4,5,6),
|
|
PARTITION p1 VALUES IN (1),
|
|
PARTITION p0 DEFAULT
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a)
|
|
(PARTITION p2 VALUES IN (4,5,6) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN (1) ENGINE = MyISAM,
|
|
PARTITION p0 DEFAULT ENGINE = MyISAM) */
|
|
insert into t1 values (10,10);
|
|
insert into t1 values (4,4);
|
|
select * from t1;
|
|
a b
|
|
4 4
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 0
|
|
p2 1
|
|
drop table t1;
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p2 VALUES IN (4,5,6),
|
|
PARTITION p1 VALUES IN (1),
|
|
PARTITION p0 DEFAULT,
|
|
PARTITION p3 DEFAULT
|
|
)
|
|
;
|
|
ERROR HY000: Only one DEFAULT partition allowed
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p0 DEFAULT,
|
|
PARTITION p2 VALUES IN (4,5,6),
|
|
PARTITION p1 VALUES IN (1),
|
|
PARTITION p3 DEFAULT
|
|
)
|
|
;
|
|
ERROR HY000: Only one DEFAULT partition allowed
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p0 DEFAULT,
|
|
PARTITION p2 VALUES IN (4,5,6),
|
|
PARTITION p1 VALUES IN (1)
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a)
|
|
(PARTITION p0 DEFAULT ENGINE = MyISAM,
|
|
PARTITION p2 VALUES IN (4,5,6) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN (1) ENGINE = MyISAM) */
|
|
insert into t1 values (10,10);
|
|
select * from t1;
|
|
a b
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 0
|
|
p2 0
|
|
drop table t1;
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p0 DEFAULT,
|
|
PARTITION p2 VALUES IN (4,5,6),
|
|
PARTITION p1 VALUES IN (1, 0)
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a)
|
|
(PARTITION p0 DEFAULT ENGINE = MyISAM,
|
|
PARTITION p2 VALUES IN (4,5,6) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN (1,0) ENGINE = MyISAM) */
|
|
insert into t1 values (10,10);
|
|
select * from t1;
|
|
a b
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 0
|
|
p2 0
|
|
drop table t1;
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST COLUMNS(a,b)
|
|
(
|
|
PARTITION p2 VALUES IN ((1,4),(2,5),(3,6)),
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)),
|
|
PARTITION p0 DEFAULT
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50500 PARTITION BY LIST COLUMNS(a,b)
|
|
(PARTITION p2 VALUES IN ((1,4),(2,5),(3,6)) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)) ENGINE = MyISAM,
|
|
PARTITION p0 DEFAULT ENGINE = MyISAM) */
|
|
insert into t1 values (10,10);
|
|
select * from t1;
|
|
a b
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 0
|
|
p2 0
|
|
drop table t1;
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST COLUMNS(a,b)
|
|
(
|
|
PARTITION p2 VALUES IN ((1,4),(2,5),(3,6)),
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)),
|
|
PARTITION p0 DEFAULT,
|
|
PARTITION p3 DEFAULT
|
|
)
|
|
;
|
|
ERROR HY000: Only one DEFAULT partition allowed
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST COLUMNS(a,b)
|
|
(
|
|
PARTITION p0 DEFAULT,
|
|
PARTITION p2 VALUES IN ((1,4),(2,5),(3,6)),
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)),
|
|
PARTITION p3 DEFAULT
|
|
)
|
|
;
|
|
ERROR HY000: Only one DEFAULT partition allowed
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p2 VALUES IN (4,5,6),
|
|
PARTITION p1 VALUES IN (1,20),
|
|
PARTITION p0 default
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a)
|
|
(PARTITION p2 VALUES IN (4,5,6) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN (1,20) ENGINE = MyISAM,
|
|
PARTITION p0 DEFAULT ENGINE = MyISAM) */
|
|
insert into t1 values (10,10);
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 0
|
|
p2 0
|
|
select * from t1 where a=10;
|
|
a b
|
|
10 10
|
|
select * from t1 where a<=10;
|
|
a b
|
|
10 10
|
|
select * from t1 where a<=20;
|
|
a b
|
|
10 10
|
|
select * from t1 where a>=10;
|
|
a b
|
|
10 10
|
|
select * from t1 where a>=5;
|
|
a b
|
|
10 10
|
|
insert into t1 values (20,20),(5,5);
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 1
|
|
p2 1
|
|
select * from t1 where a=10;
|
|
a b
|
|
10 10
|
|
select * from t1 where a<=10;
|
|
a b
|
|
5 5
|
|
10 10
|
|
select * from t1 where a<=20;
|
|
a b
|
|
5 5
|
|
20 20
|
|
10 10
|
|
select * from t1 where a>=10;
|
|
a b
|
|
20 20
|
|
10 10
|
|
select * from t1 where a>=5;
|
|
a b
|
|
5 5
|
|
20 20
|
|
10 10
|
|
explain partitions select * from t1 where a=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
explain partitions select * from t1 where a=5;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2 system NULL NULL NULL NULL 1
|
|
select * from t1 where a=10 or a=5;
|
|
a b
|
|
5 5
|
|
10 10
|
|
explain partitions select * from t1 where a=10 or a=5;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2,p0 ALL NULL NULL NULL NULL 2 Using where
|
|
drop table t1;
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST COLUMNS(a,b)
|
|
(
|
|
PARTITION p2 VALUES IN ((1,4),(2,5),(3,6),(5,5)),
|
|
PARTITION p1 VALUES IN ((1,1),(20,20)),
|
|
PARTITION p0 DEFAULT
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50500 PARTITION BY LIST COLUMNS(a,b)
|
|
(PARTITION p2 VALUES IN ((1,4),(2,5),(3,6),(5,5)) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN ((1,1),(20,20)) ENGINE = MyISAM,
|
|
PARTITION p0 DEFAULT ENGINE = MyISAM) */
|
|
insert into t1 values (10,10);
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 0
|
|
p2 0
|
|
select * from t1 where a=10 and b=10;
|
|
a b
|
|
10 10
|
|
explain partitions select * from t1 where a=10 and b=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
select * from t1 where a=10;
|
|
a b
|
|
10 10
|
|
explain partitions select * from t1 where a=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
select * from t1 where a<=10;
|
|
a b
|
|
10 10
|
|
select * from t1 where a>=10;
|
|
a b
|
|
10 10
|
|
insert into t1 values (20,20),(5,5);
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 1
|
|
p2 1
|
|
select * from t1 where a=10 and b=10;
|
|
a b
|
|
10 10
|
|
explain partitions select * from t1 where a=10 and b=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
select * from t1 where a=10 and b=10 or a=20 and b=20;
|
|
a b
|
|
20 20
|
|
10 10
|
|
explain partitions select * from t1 where a=10 and b=10 or a=20 and b=20;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p1,p0 ALL NULL NULL NULL NULL 2 Using where
|
|
drop table t1;
|
|
create table t1 (a int, b int);
|
|
insert into t1 values (10,10),(2,5),(0,0);
|
|
select * from t1;
|
|
a b
|
|
10 10
|
|
2 5
|
|
0 0
|
|
alter table t1
|
|
PARTITION BY LIST (a+b)
|
|
(
|
|
PARTITION p2 VALUES IN (1,2,3,7),
|
|
PARTITION p1 VALUES IN (21,0),
|
|
PARTITION p0 DEFAULT
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a+b)
|
|
(PARTITION p2 VALUES IN (1,2,3,7) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN (21,0) ENGINE = MyISAM,
|
|
PARTITION p0 DEFAULT ENGINE = MyISAM) */
|
|
select * from t1;
|
|
a b
|
|
2 5
|
|
0 0
|
|
10 10
|
|
explain partitions select * from t1 where a=2 and b=5;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2 system NULL NULL NULL NULL 1
|
|
explain partitions select * from t1 where a=10 and b=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
drop table t1;
|
|
create table t1 (a int, b int);
|
|
insert into t1 values (10,10),(2,5),(0,0);
|
|
select * from t1;
|
|
a b
|
|
10 10
|
|
2 5
|
|
0 0
|
|
alter table t1
|
|
PARTITION BY LIST (a+5)
|
|
(
|
|
PARTITION p2 VALUES IN (1,2,3,7),
|
|
PARTITION p1 VALUES IN (0),
|
|
PARTITION p0 DEFAULT
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a+5)
|
|
(PARTITION p2 VALUES IN (1,2,3,7) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN (0) ENGINE = MyISAM,
|
|
PARTITION p0 DEFAULT ENGINE = MyISAM) */
|
|
select * from t1;
|
|
a b
|
|
2 5
|
|
10 10
|
|
0 0
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 2
|
|
p1 0
|
|
p2 1
|
|
explain partitions select * from t1 where a>=2;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2,p1,p0 ALL NULL NULL NULL NULL 3 Using where
|
|
explain partitions select * from t1 where a>=2 and a<=3;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2,p0 ALL NULL NULL NULL NULL 3 Using where
|
|
explain partitions select * from t1 where a=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 ALL NULL NULL NULL NULL 2 Using where
|
|
drop table t1;
|
|
CREATE TABLE t1 (a DATE, KEY(a))
|
|
PARTITION BY LIST (TO_DAYS(a))
|
|
(PARTITION `pDEF` DEFAULT,
|
|
PARTITION `p2001-01-01` VALUES IN (TO_DAYS('2001-01-01')),
|
|
PARTITION `pNULL` VALUES IN (NULL),
|
|
PARTITION `p0000-01-02` VALUES IN (TO_DAYS('0000-01-02')),
|
|
PARTITION `p1001-01-01` VALUES IN (TO_DAYS('1001-01-01')));
|
|
INSERT INTO t1 VALUES ('0000-00-00'), ('0000-01-02'), ('0001-01-01'),
|
|
('1001-00-00'), ('1001-01-01'), ('1002-00-00'), ('2001-01-01');
|
|
SELECT * FROM t1 WHERE a < '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
SELECT * FROM t1 WHERE a <= '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a >= '1001-01-01';
|
|
a
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1001-01-01';
|
|
a
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1001-01-01';
|
|
a
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a < '1001-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
SELECT * FROM t1 WHERE a <= '1001-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
SELECT * FROM t1 WHERE a >= '1001-00-00';
|
|
a
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1001-00-00';
|
|
a
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1001-00-00';
|
|
a
|
|
1001-00-00
|
|
# Disabling warnings for the invalid date
|
|
SELECT * FROM t1 WHERE a < '1999-02-31';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a <= '1999-02-31';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a >= '1999-02-31';
|
|
a
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1999-02-31';
|
|
a
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1999-02-31';
|
|
a
|
|
SELECT * FROM t1 WHERE a BETWEEN '0000-00-00' AND '1002-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a BETWEEN '0000-00-00' AND '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a BETWEEN '0001-01-02' AND '1002-00-00';
|
|
a
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a BETWEEN '0001-01-01' AND '1001-01-01';
|
|
a
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
# test without index
|
|
ALTER TABLE t1 DROP KEY a;
|
|
SELECT * FROM t1 WHERE a < '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
SELECT * FROM t1 WHERE a <= '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a >= '1001-01-01';
|
|
a
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1001-01-01';
|
|
a
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1001-01-01';
|
|
a
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a < '1001-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
SELECT * FROM t1 WHERE a <= '1001-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
SELECT * FROM t1 WHERE a >= '1001-00-00';
|
|
a
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1001-00-00';
|
|
a
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1001-00-00';
|
|
a
|
|
1001-00-00
|
|
# Disabling warnings for the invalid date
|
|
SELECT * FROM t1 WHERE a < '1999-02-31';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a <= '1999-02-31';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a >= '1999-02-31';
|
|
a
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1999-02-31';
|
|
a
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1999-02-31';
|
|
a
|
|
SELECT * FROM t1 WHERE a BETWEEN '0000-00-00' AND '1002-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a BETWEEN '0000-00-00' AND '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a BETWEEN '0001-01-02' AND '1002-00-00';
|
|
a
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a BETWEEN '0001-01-01' AND '1001-01-01';
|
|
a
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
DROP TABLE t1;
|
|
# TO_SECONDS, test of LIST and index
|
|
CREATE TABLE t1 (a DATE, KEY(a))
|
|
PARTITION BY LIST (TO_SECONDS(a))
|
|
(PARTITION `pDEF` DEFAULT,
|
|
PARTITION `p2001-01-01` VALUES IN (TO_SECONDS('2001-01-01')),
|
|
PARTITION `pNULL` VALUES IN (NULL),
|
|
PARTITION `p0000-01-02` VALUES IN (TO_SECONDS('0000-01-02')),
|
|
PARTITION `p1001-01-01` VALUES IN (TO_SECONDS('1001-01-01')));
|
|
INSERT INTO t1 VALUES ('0000-00-00'), ('0000-01-02'), ('0001-01-01'),
|
|
('1001-00-00'), ('1001-01-01'), ('1002-00-00'), ('2001-01-01');
|
|
SELECT * FROM t1 WHERE a < '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
SELECT * FROM t1 WHERE a <= '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a >= '1001-01-01';
|
|
a
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1001-01-01';
|
|
a
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1001-01-01';
|
|
a
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a < '1001-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
SELECT * FROM t1 WHERE a <= '1001-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
SELECT * FROM t1 WHERE a >= '1001-00-00';
|
|
a
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1001-00-00';
|
|
a
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1001-00-00';
|
|
a
|
|
1001-00-00
|
|
# Disabling warnings for the invalid date
|
|
SELECT * FROM t1 WHERE a < '1999-02-31';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a <= '1999-02-31';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a >= '1999-02-31';
|
|
a
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1999-02-31';
|
|
a
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1999-02-31';
|
|
a
|
|
SELECT * FROM t1 WHERE a BETWEEN '0000-00-00' AND '1002-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a BETWEEN '0000-00-00' AND '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a BETWEEN '0001-01-02' AND '1002-00-00';
|
|
a
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a BETWEEN '0001-01-01' AND '1001-01-01';
|
|
a
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
# test without index
|
|
ALTER TABLE t1 DROP KEY a;
|
|
SELECT * FROM t1 WHERE a < '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
SELECT * FROM t1 WHERE a <= '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a >= '1001-01-01';
|
|
a
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1001-01-01';
|
|
a
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1001-01-01';
|
|
a
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a < '1001-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
SELECT * FROM t1 WHERE a <= '1001-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
SELECT * FROM t1 WHERE a >= '1001-00-00';
|
|
a
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1001-00-00';
|
|
a
|
|
1001-01-01
|
|
1002-00-00
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1001-00-00';
|
|
a
|
|
1001-00-00
|
|
# Disabling warnings for the invalid date
|
|
SELECT * FROM t1 WHERE a < '1999-02-31';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a <= '1999-02-31';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a >= '1999-02-31';
|
|
a
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a > '1999-02-31';
|
|
a
|
|
2001-01-01
|
|
SELECT * FROM t1 WHERE a = '1999-02-31';
|
|
a
|
|
SELECT * FROM t1 WHERE a BETWEEN '0000-00-00' AND '1002-00-00';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a BETWEEN '0000-00-00' AND '1001-01-01';
|
|
a
|
|
0000-00-00
|
|
0000-01-02
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
SELECT * FROM t1 WHERE a BETWEEN '0001-01-02' AND '1002-00-00';
|
|
a
|
|
1001-00-00
|
|
1001-01-01
|
|
1002-00-00
|
|
SELECT * FROM t1 WHERE a BETWEEN '0001-01-01' AND '1001-01-01';
|
|
a
|
|
0001-01-01
|
|
1001-00-00
|
|
1001-01-01
|
|
DROP TABLE t1;
|
|
create table t1 (a int, b int);
|
|
insert into t1 values (10,10),(2,5),(0,0);
|
|
select * from t1;
|
|
a b
|
|
10 10
|
|
2 5
|
|
0 0
|
|
alter table t1
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p2 VALUES IN (1,2,3),
|
|
PARTITION p1 VALUES IN (20,0),
|
|
PARTITION p0 DEFAULT
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a)
|
|
(PARTITION p2 VALUES IN (1,2,3) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN (20,0) ENGINE = MyISAM,
|
|
PARTITION p0 DEFAULT ENGINE = MyISAM) */
|
|
select * from t1;
|
|
a b
|
|
2 5
|
|
0 0
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 1
|
|
p2 1
|
|
explain partitions select * from t1 where a=2 and b=5;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2 system NULL NULL NULL NULL 1
|
|
explain partitions select * from t1 where a=10 and b=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
alter table t1
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p2 VALUES IN (1,2,3),
|
|
PARTITION p1 VALUES IN (20,0),
|
|
PARTITION p0 VALUES IN (10)
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a)
|
|
(PARTITION p2 VALUES IN (1,2,3) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN (20,0) ENGINE = MyISAM,
|
|
PARTITION p0 VALUES IN (10) ENGINE = MyISAM) */
|
|
select * from t1;
|
|
a b
|
|
2 5
|
|
0 0
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 1
|
|
p2 1
|
|
explain partitions select * from t1 where a=2 and b=5;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2 system NULL NULL NULL NULL 1
|
|
explain partitions select * from t1 where a=10 and b=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
alter table t1
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p2 DEFAULT,
|
|
PARTITION p1 VALUES IN (20,0),
|
|
PARTITION p0 VALUES IN (10)
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a)
|
|
(PARTITION p2 DEFAULT ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN (20,0) ENGINE = MyISAM,
|
|
PARTITION p0 VALUES IN (10) ENGINE = MyISAM) */
|
|
select * from t1;
|
|
a b
|
|
2 5
|
|
0 0
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 1
|
|
p2 1
|
|
explain partitions select * from t1 where a=2 and b=5;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2 system NULL NULL NULL NULL 1
|
|
explain partitions select * from t1 where a=10 and b=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
alter table t1 drop partition p2;
|
|
ERROR HY000: Table has no partition for value 2
|
|
delete from t1 where a=2;
|
|
alter table t1 drop partition p2;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a)
|
|
(PARTITION p1 VALUES IN (20,0) ENGINE = MyISAM,
|
|
PARTITION p0 VALUES IN (10) ENGINE = MyISAM) */
|
|
select * from t1;
|
|
a b
|
|
0 0
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 1
|
|
alter table t1 add partition (PARTITION pd DEFAULT);
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50100 PARTITION BY LIST (a)
|
|
(PARTITION p1 VALUES IN (20,0) ENGINE = MyISAM,
|
|
PARTITION p0 VALUES IN (10) ENGINE = MyISAM,
|
|
PARTITION pd DEFAULT ENGINE = MyISAM) */
|
|
alter table t1 add partition (PARTITION pdd DEFAULT);
|
|
ERROR HY000: Only one DEFAULT partition allowed
|
|
alter table t1 drop partition pd;
|
|
alter table t1 add partition (PARTITION pdd DEFAULT,
|
|
PARTITION pd DEFAULT);
|
|
ERROR HY000: Only one DEFAULT partition allowed
|
|
drop table t1;
|
|
create table t1 (a int, b int);
|
|
insert into t1 values (10,10),(2,5),(0,0);
|
|
select * from t1;
|
|
a b
|
|
10 10
|
|
2 5
|
|
0 0
|
|
alter table t1
|
|
PARTITION BY LIST COLUMNS(a,b)
|
|
(
|
|
PARTITION p2 VALUES IN ((1,4),(2,5),(3,6)),
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)),
|
|
PARTITION p0 DEFAULT
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50500 PARTITION BY LIST COLUMNS(a,b)
|
|
(PARTITION p2 VALUES IN ((1,4),(2,5),(3,6)) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)) ENGINE = MyISAM,
|
|
PARTITION p0 DEFAULT ENGINE = MyISAM) */
|
|
select * from t1;
|
|
a b
|
|
2 5
|
|
0 0
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 1
|
|
p2 1
|
|
explain partitions select * from t1 where a=2 and b=5;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2 system NULL NULL NULL NULL 1
|
|
explain partitions select * from t1 where a=10 and b=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
alter table t1
|
|
PARTITION BY LIST COLUMNS(a,b)
|
|
(
|
|
PARTITION p2 VALUES IN ((1,4),(2,5),(3,6)),
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)),
|
|
PARTITION p0 VALUES IN ((10,10))
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50500 PARTITION BY LIST COLUMNS(a,b)
|
|
(PARTITION p2 VALUES IN ((1,4),(2,5),(3,6)) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)) ENGINE = MyISAM,
|
|
PARTITION p0 VALUES IN ((10,10)) ENGINE = MyISAM) */
|
|
select * from t1;
|
|
a b
|
|
2 5
|
|
0 0
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 1
|
|
p2 1
|
|
explain partitions select * from t1 where a=2 and b=5;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2 system NULL NULL NULL NULL 1
|
|
explain partitions select * from t1 where a=10 and b=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
alter table t1
|
|
PARTITION BY LIST COLUMNS(a,b)
|
|
(
|
|
PARTITION p2 DEFAULT,
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)),
|
|
PARTITION p0 VALUES IN ((10,10))
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50500 PARTITION BY LIST COLUMNS(a,b)
|
|
(PARTITION p2 DEFAULT ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)) ENGINE = MyISAM,
|
|
PARTITION p0 VALUES IN ((10,10)) ENGINE = MyISAM) */
|
|
select * from t1;
|
|
a b
|
|
2 5
|
|
0 0
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 1
|
|
p2 1
|
|
explain partitions select * from t1 where a=2 and b=5;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2 system NULL NULL NULL NULL 1
|
|
explain partitions select * from t1 where a=10 and b=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
alter table t1 drop partition p2;
|
|
ERROR HY000: Table has no partition for value from column_list
|
|
delete from t1 where a=2;
|
|
alter table t1 drop partition p2;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50500 PARTITION BY LIST COLUMNS(a,b)
|
|
(PARTITION p1 VALUES IN ((1,1),(0,0)) ENGINE = MyISAM,
|
|
PARTITION p0 VALUES IN ((10,10)) ENGINE = MyISAM) */
|
|
select * from t1;
|
|
a b
|
|
0 0
|
|
10 10
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 1
|
|
p1 1
|
|
alter table t1 add partition (PARTITION pd DEFAULT);
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50500 PARTITION BY LIST COLUMNS(a,b)
|
|
(PARTITION p1 VALUES IN ((1,1),(0,0)) ENGINE = MyISAM,
|
|
PARTITION p0 VALUES IN ((10,10)) ENGINE = MyISAM,
|
|
PARTITION pd DEFAULT ENGINE = MyISAM) */
|
|
alter table t1 add partition (PARTITION pdd DEFAULT);
|
|
ERROR HY000: Only one DEFAULT partition allowed
|
|
alter table t1 drop partition pd;
|
|
alter table t1 add partition (PARTITION pdd DEFAULT,
|
|
PARTITION pd DEFAULT);
|
|
ERROR HY000: Only one DEFAULT partition allowed
|
|
drop table t1;
|
|
create table t1 (a int)
|
|
PARTITION BY LIST (a)
|
|
(
|
|
PARTITION p2 VALUES IN (4,5,6),
|
|
PARTITION p1 VALUES IN (1),
|
|
PARTITION pd DEFAULT
|
|
)
|
|
;
|
|
insert into t1 values (1),(2),(3),(4);
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p1 1
|
|
p2 1
|
|
pd 2
|
|
alter table t1 add partition
|
|
(partition p0 VALUES IN (2,3));
|
|
select partition_name, table_rows from INFORMATION_SCHEMA.PARTITIONS where table_name='t1';
|
|
partition_name table_rows
|
|
p0 2
|
|
p1 1
|
|
p2 1
|
|
pd 0
|
|
drop table t1;
|
|
create table t1 (a int, b int)
|
|
PARTITION BY LIST COLUMNS(a,b)
|
|
(
|
|
PARTITION p0 DEFAULT,
|
|
PARTITION p2 VALUES IN ((1,4),(2,5),(3,6)),
|
|
PARTITION p1 VALUES IN ((1,1),(0,0))
|
|
)
|
|
;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
/*!50500 PARTITION BY LIST COLUMNS(a,b)
|
|
(PARTITION p0 DEFAULT ENGINE = MyISAM,
|
|
PARTITION p2 VALUES IN ((1,4),(2,5),(3,6)) ENGINE = MyISAM,
|
|
PARTITION p1 VALUES IN ((1,1),(0,0)) ENGINE = MyISAM) */
|
|
drop table t1;
|
|
#
|
|
# MDEV-10765: Wrong result - query does not retrieve values from
|
|
# default partition on a table partitioned by list columns
|
|
#
|
|
create table t1 (i int, j int) partition by list columns(i,j) (partition p1 values in ((10,10)), partition p2 default);
|
|
insert into t1 values (10,1);
|
|
select * from t1 where i = 10;
|
|
i j
|
|
10 1
|
|
explain partitions
|
|
select * from t1 where i = 10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p1,p2 system NULL NULL NULL NULL 1
|
|
select * from t1 where i = 10 and j=1;
|
|
i j
|
|
10 1
|
|
explain partitions
|
|
select * from t1 where i = 10 and j=1;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2 system NULL NULL NULL NULL 1
|
|
insert into t1 values (10,10);
|
|
select * from t1 where i = 10 and j=10;
|
|
i j
|
|
10 10
|
|
explain partitions
|
|
select * from t1 where i = 10 and j=10;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p1 system NULL NULL NULL NULL 1
|
|
drop table t1;
|
|
create table t1
|
|
(
|
|
a int not null,
|
|
b int not null,
|
|
c int
|
|
)
|
|
partition by list columns(a,b)
|
|
(
|
|
partition p1 values in ((10,10)),
|
|
partition p2 values in ((10,20)),
|
|
partition p3 values in ((10,30)),
|
|
partition p4 values in ((10,40)),
|
|
partition p5 values in ((10,50))
|
|
);
|
|
insert into t1 values
|
|
(10,10,1234),
|
|
(10,20,1234),
|
|
(10,30,1234),
|
|
(10,40,1234),
|
|
(10,50,1234);
|
|
explain partitions
|
|
select * from t1
|
|
where a>=10 and (a <=10 and b <=30);
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p1,p2,p3 ALL NULL NULL NULL NULL 3 Using where
|
|
drop table t1;
|
|
#
|
|
# MDEV-10763: Wrong result - server does not return NULL values
|
|
# from default list partition after ALTER table
|
|
#
|
|
create table t1 (i int) partition by list (i) ( partition p1 default);
|
|
insert into t1 values (null);
|
|
select * from t1 where i is null;
|
|
i
|
|
NULL
|
|
alter table t1 partition by list (i) ( partition p1 values in (1), partition p2 default);
|
|
select * from t1 where i is null;
|
|
i
|
|
NULL
|
|
explain partitions
|
|
select * from t1 where i is null;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p2 system NULL NULL NULL NULL 1
|
|
alter table t1 partition by list (i) (
|
|
partition p0 values in (NULL),
|
|
partition p1 values in (1),
|
|
partition p2 default);
|
|
select * from t1 where i is null;
|
|
i
|
|
NULL
|
|
explain partitions
|
|
select * from t1 where i is null;
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 p0 system NULL NULL NULL NULL 1
|
|
drop table t1;
|