partition_date.inc 2.25 KB
Newer Older
1 2
eval create table t1 (a date not null, primary key(a)) engine=$engine 
partition by key (a) (
3 4 5 6
partition pa1 max_rows=20 min_rows=2,
partition pa2 max_rows=30 min_rows=3,
partition pa3 max_rows=30 min_rows=4,
partition pa4 max_rows=40 min_rows=2);
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
show create table t1;
insert into t1 values ('1975-01-01'), ('2020-12-31'), ('1980-10-14'), ('2000-06-15');
select * from t1;
select * from t1 where a=19801014;
delete from t1 where a=19801014;
select * from t1;
drop table t1;

eval create table t2 (a date not null, primary key(a)) engine=$engine 
partition by key (a) partitions 12;
show create table t2;
insert into t2 values ('1975-01-01'), ('2020-12-31'), ('1980-10-14'), ('2000-06-15');
select * from t2;
select * from t2 where a='1980-10-14';
delete from t2 where a='1980-10-14';
select * from t2;
delete from t2;
let $count=28;
--echo $count inserts;
Michael Widenius's avatar
Michael Widenius committed
26 27
--disable_query_log
begin;
28 29 30 31 32 33 34
while ($count)
{
eval insert into t2 values (19700101+$count-1);
eval insert into t2 values (19700201+$count-1);
eval insert into t2 values (19700301+$count-1);
dec $count;
}
Michael Widenius's avatar
Michael Widenius committed
35 36
commit;
--enable_query_log
37 38 39 40 41
select count(*) from t2;
select * from t2;
drop table t2;

eval create table t3 (a date not null, primary key(a)) engine=$engine 
unknown's avatar
unknown committed
42
partition by range (month(a)) subpartition by key (a)
43 44 45 46 47 48 49 50 51
subpartitions 3 (
partition quarter1 values less than (4),
partition quarter2 values less than (7),
partition quarter3 values less than (10), 
partition quarter4 values less than (13)
);
show create table t3;
let $count=12;
--echo $count inserts;
Michael Widenius's avatar
Michael Widenius committed
52 53
--disable_query_log
begin;
54 55 56 57 58
while ($count)
{
eval insert into t3 values (adddate(19700101,interval $count-1 month));
dec $count;
}
Michael Widenius's avatar
Michael Widenius committed
59 60
commit;
--enable_query_log
61 62 63 64 65
select count(*) from t3;
select * from t3;
drop table t3;

eval create table t4 (a date not null, primary key(a)) engine=$engine 
unknown's avatar
unknown committed
66
partition by list (month(a)) subpartition by key (a)
67 68 69 70 71 72 73 74 75
subpartitions 3 (
partition quarter1 values in (1,2,3),
partition quarter2 values in (4,5,6),
partition quarter3 values in (7,8,9), 
partition quarter4 values in (10,11,12)
);
show create table t4;
let $count=12;
--echo $count inserts;
Michael Widenius's avatar
Michael Widenius committed
76 77
--disable_query_log
begin;
78 79 80 81 82
while ($count)
{
eval insert into t4 values (adddate(19700101,interval $count-1 month));
dec $count;
}
Michael Widenius's avatar
Michael Widenius committed
83 84
commit;
--enable_query_log
85 86 87
select count(*) from t4;
select * from t4;
drop table t4;