Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
40496deb
Commit
40496deb
authored
Oct 29, 2009
by
Mikael Ronstrom
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Changed COLUMN_LIST to COLUMNS after arch review
parent
840d7eb4
Changes
12
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
139 additions
and
141 deletions
+139
-141
mysql-test/r/partition_column.result
mysql-test/r/partition_column.result
+81
-81
mysql-test/r/partition_column_prune.result
mysql-test/r/partition_column_prune.result
+3
-3
mysql-test/r/partition_innodb.result
mysql-test/r/partition_innodb.result
+3
-3
mysql-test/r/partition_range.result
mysql-test/r/partition_range.result
+2
-2
mysql-test/t/partition_column.test
mysql-test/t/partition_column.test
+37
-37
mysql-test/t/partition_column_prune.test
mysql-test/t/partition_column_prune.test
+3
-3
mysql-test/t/partition_innodb.test
mysql-test/t/partition_innodb.test
+3
-3
mysql-test/t/partition_range.test
mysql-test/t/partition_range.test
+2
-2
sql/lex.h
sql/lex.h
+0
-1
sql/opt_range.cc
sql/opt_range.cc
+1
-1
sql/sql_partition.cc
sql/sql_partition.cc
+3
-3
sql/sql_yacc.yy
sql/sql_yacc.yy
+1
-2
No files found.
mysql-test/r/partition_column.result
View file @
40496deb
This diff is collapsed.
Click to expand it.
mysql-test/r/partition_column_prune.result
View file @
40496deb
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
create table t1 (a char, b char, c char)
create table t1 (a char, b char, c char)
partition by range column
_list
(a,b,c)
partition by range column
s
(a,b,c)
( partition p0 values less than ('a','b','c'));
( partition p0 values less than ('a','b','c'));
insert into t1 values ('a', NULL, 'd');
insert into t1 values ('a', NULL, 'd');
explain partitions select * from t1 where a = 'a' AND c = 'd';
explain partitions select * from t1 where a = 'a' AND c = 'd';
...
@@ -10,7 +10,7 @@ select * from t1 where a = 'a' AND c = 'd';
...
@@ -10,7 +10,7 @@ select * from t1 where a = 'a' AND c = 'd';
a b c
a b c
a NULL d
a NULL d
drop table t1;
drop table t1;
create table t1 (a int not null) partition by range column
_list
(a) (
create table t1 (a int not null) partition by range column
s
(a) (
partition p0 values less than (10),
partition p0 values less than (10),
partition p1 values less than (20),
partition p1 values less than (20),
partition p2 values less than (30),
partition p2 values less than (30),
...
@@ -40,7 +40,7 @@ id select_type table partitions type possible_keys key key_len ref rows Extra
...
@@ -40,7 +40,7 @@ id select_type table partitions type possible_keys key key_len ref rows Extra
1 SIMPLE t2 p3,p4 ALL NULL NULL NULL NULL 4 Using where
1 SIMPLE t2 p3,p4 ALL NULL NULL NULL NULL 4 Using where
drop table t1, t2;
drop table t1, t2;
create table t1 (a int not null, b int not null )
create table t1 (a int not null, b int not null )
partition by range column
_list
(a,b) (
partition by range column
s
(a,b) (
partition p01 values less than (2,10),
partition p01 values less than (2,10),
partition p02 values less than (2,20),
partition p02 values less than (2,20),
partition p03 values less than (2,30),
partition p03 values less than (2,30),
...
...
mysql-test/r/partition_innodb.result
View file @
40496deb
drop table if exists t1;
drop table if exists t1;
create table t1 (a varchar(5))
create table t1 (a varchar(5))
engine=memory
engine=memory
partition by range column
_list
(a)
partition by range column
s
(a)
( partition p0 values less than ('m'),
( partition p0 values less than ('m'),
partition p1 values less than ('za'));
partition p1 values less than ('za'));
insert into t1 values ('j');
insert into t1 values ('j');
...
@@ -9,7 +9,7 @@ update t1 set a = 'z' where (a >= 'j');
...
@@ -9,7 +9,7 @@ update t1 set a = 'z' where (a >= 'j');
drop table t1;
drop table t1;
create table t1 (a varchar(5))
create table t1 (a varchar(5))
engine=myisam
engine=myisam
partition by range column
_list
(a)
partition by range column
s
(a)
( partition p0 values less than ('m'),
( partition p0 values less than ('m'),
partition p1 values less than ('za'));
partition p1 values less than ('za'));
insert into t1 values ('j');
insert into t1 values ('j');
...
@@ -17,7 +17,7 @@ update t1 set a = 'z' where (a >= 'j');
...
@@ -17,7 +17,7 @@ update t1 set a = 'z' where (a >= 'j');
drop table t1;
drop table t1;
create table t1 (a varchar(5))
create table t1 (a varchar(5))
engine=innodb
engine=innodb
partition by range column
_list
(a)
partition by range column
s
(a)
( partition p0 values less than ('m'),
( partition p0 values less than ('m'),
partition p1 values less than ('za'));
partition p1 values less than ('za'));
insert into t1 values ('j');
insert into t1 values ('j');
...
...
mysql-test/r/partition_range.result
View file @
40496deb
...
@@ -77,7 +77,7 @@ a
...
@@ -77,7 +77,7 @@ a
2004-01-01 11:59:29
2004-01-01 11:59:29
drop table t1;
drop table t1;
create table t1 (a int, b char(20))
create table t1 (a int, b char(20))
partition by range column
_list
(a,b)
partition by range column
s
(a,b)
(partition p0 values less than (1));
(partition p0 values less than (1));
ERROR 42000: Inconsistency in usage of column lists for partitioning near '))' at line 3
ERROR 42000: Inconsistency in usage of column lists for partitioning near '))' at line 3
create table t1 (a int, b char(20))
create table t1 (a int, b char(20))
...
@@ -89,7 +89,7 @@ partition by range(a)
...
@@ -89,7 +89,7 @@ partition by range(a)
(partition p0 values less than (1,"b"));
(partition p0 values less than (1,"b"));
ERROR HY000: Cannot have more than one value for this type of RANGE partitioning
ERROR HY000: Cannot have more than one value for this type of RANGE partitioning
create table t1 (a int, b char(20))
create table t1 (a int, b char(20))
partition by range column
_list
(b)
partition by range column
s
(b)
(partition p0 values less than ("b"));
(partition p0 values less than ("b"));
drop table t1;
drop table t1;
create table t1 (a int)
create table t1 (a int)
...
...
mysql-test/t/partition_column.test
View file @
40496deb
...
@@ -13,11 +13,11 @@ drop table if exists t1;
...
@@ -13,11 +13,11 @@ drop table if exists t1;
#
#
--
error
ER_PARTITION_FIELDS_TOO_LONG
--
error
ER_PARTITION_FIELDS_TOO_LONG
create
table
t1
(
a
varchar
(
1500
),
b
varchar
(
1570
))
create
table
t1
(
a
varchar
(
1500
),
b
varchar
(
1570
))
partition
by
list
column
_list
(
a
,
b
)
partition
by
list
column
s
(
a
,
b
)
(
partition
p0
values
in
((
'a'
,
'b'
)));
(
partition
p0
values
in
((
'a'
,
'b'
)));
create
table
t1
(
a
varchar
(
1023
)
character
set
utf8
collate
utf8_spanish2_ci
)
create
table
t1
(
a
varchar
(
1023
)
character
set
utf8
collate
utf8_spanish2_ci
)
partition
by
range
column
_list
(
a
)
partition
by
range
column
s
(
a
)
(
partition
p0
values
less
than
(
'CZ'
),
(
partition
p0
values
less
than
(
'CZ'
),
partition
p1
values
less
than
(
'CH'
),
partition
p1
values
less
than
(
'CH'
),
partition
p2
values
less
than
(
'D'
));
partition
p2
values
less
than
(
'D'
));
...
@@ -31,12 +31,12 @@ drop table t1;
...
@@ -31,12 +31,12 @@ drop table t1;
set
@@
sql_mode
=
allow_invalid_dates
;
set
@@
sql_mode
=
allow_invalid_dates
;
--
error
ER_WRONG_TYPE_COLUMN_VALUE_ERROR
--
error
ER_WRONG_TYPE_COLUMN_VALUE_ERROR
create
table
t1
(
a
char
,
b
char
,
c
date
)
create
table
t1
(
a
char
,
b
char
,
c
date
)
partition
by
range
column
_list
(
a
,
b
,
c
)
partition
by
range
column
s
(
a
,
b
,
c
)
(
partition
p0
values
less
than
(
0
,
0
,
to_days
(
'3000-11-31'
)));
(
partition
p0
values
less
than
(
0
,
0
,
to_days
(
'3000-11-31'
)));
--
error
ER_WRONG_TYPE_COLUMN_VALUE_ERROR
--
error
ER_WRONG_TYPE_COLUMN_VALUE_ERROR
create
table
t1
(
a
char
,
b
char
,
c
date
)
create
table
t1
(
a
char
,
b
char
,
c
date
)
partition
by
range
column
_list
(
a
,
b
,
c
)
partition
by
range
column
s
(
a
,
b
,
c
)
(
partition
p0
values
less
than
(
0
,
0
,
'3000-11-31'
));
(
partition
p0
values
less
than
(
0
,
0
,
'3000-11-31'
));
set
@@
sql_mode
=
''
;
set
@@
sql_mode
=
''
;
...
@@ -44,7 +44,7 @@ set @@sql_mode='';
...
@@ -44,7 +44,7 @@ set @@sql_mode='';
# BUG#48163, Dagger in UCS2 not working as partition value
# BUG#48163, Dagger in UCS2 not working as partition value
#
#
create
table
t1
(
a
varchar
(
2
)
character
set
ucs2
)
create
table
t1
(
a
varchar
(
2
)
character
set
ucs2
)
partition
by
list
column
_list
(
a
)
partition
by
list
column
s
(
a
)
(
partition
p0
values
in
(
0x2020
),
(
partition
p0
values
in
(
0x2020
),
partition
p1
values
in
(
''
));
partition
p1
values
in
(
''
));
show
create
table
t1
;
show
create
table
t1
;
...
@@ -53,7 +53,7 @@ insert into t1 values (_ucs2 0x2020);
...
@@ -53,7 +53,7 @@ insert into t1 values (_ucs2 0x2020);
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
int
,
b
char
(
10
),
c
varchar
(
25
),
d
datetime
)
create
table
t1
(
a
int
,
b
char
(
10
),
c
varchar
(
25
),
d
datetime
)
partition
by
range
column
_list
(
a
,
b
,
c
,
d
)
partition
by
range
column
s
(
a
,
b
,
c
,
d
)
subpartition
by
hash
(
to_seconds
(
d
))
subpartition
by
hash
(
to_seconds
(
d
))
subpartitions
4
subpartitions
4
(
partition
p0
values
less
than
(
1
,
0
,
MAXVALUE
,
'1900-01-01'
),
(
partition
p0
values
less
than
(
1
,
0
,
MAXVALUE
,
'1900-01-01'
),
...
@@ -67,16 +67,16 @@ drop table t1;
...
@@ -67,16 +67,16 @@ drop table t1;
--
error
ER_NULL_IN_VALUES_LESS_THAN
--
error
ER_NULL_IN_VALUES_LESS_THAN
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
range
column
_list
(
a
,
b
)
partition
by
range
column
s
(
a
,
b
)
(
partition
p0
values
less
than
(
NULL
,
maxvalue
));
(
partition
p0
values
less
than
(
NULL
,
maxvalue
));
--
error
ER_MAXVALUE_IN_VALUES_IN
,
ER_PARSE_ERROR
--
error
ER_MAXVALUE_IN_VALUES_IN
,
ER_PARSE_ERROR
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
list
column
_list
(
a
,
b
)
partition
by
list
column
s
(
a
,
b
)
(
partition
p0
values
in
((
maxvalue
,
0
)));
(
partition
p0
values
in
((
maxvalue
,
0
)));
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
list
column
_list
(
a
,
b
)
partition
by
list
column
s
(
a
,
b
)
(
partition
p0
values
in
((
0
,
0
)));
(
partition
p0
values
in
((
0
,
0
)));
--
error
ER_MAXVALUE_IN_VALUES_IN
,
ER_PARSE_ERROR
--
error
ER_MAXVALUE_IN_VALUES_IN
,
ER_PARSE_ERROR
alter
table
t1
add
partition
alter
table
t1
add
partition
...
@@ -90,7 +90,7 @@ create table t1 (a int, b int)
...
@@ -90,7 +90,7 @@ create table t1 (a int, b int)
partition
by
key
(
a
,
a
);
partition
by
key
(
a
,
a
);
--
error
ER_SAME_NAME_PARTITION_FIELD
--
error
ER_SAME_NAME_PARTITION_FIELD
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
list
column
_list
(
a
,
a
)
partition
by
list
column
s
(
a
,
a
)
(
partition
p
values
in
((
1
,
1
)));
(
partition
p
values
in
((
1
,
1
)));
#
#
...
@@ -108,7 +108,7 @@ select * from t1 where a <= 1;
...
@@ -108,7 +108,7 @@ select * from t1 where a <= 1;
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
int
signed
)
create
table
t1
(
a
int
signed
)
partition
by
list
column
_list
(
a
)
partition
by
list
column
s
(
a
)
(
partition
p0
values
in
(
1
,
3
,
5
,
7
,
9
,
NULL
),
(
partition
p0
values
in
(
1
,
3
,
5
,
7
,
9
,
NULL
),
partition
p1
values
in
(
2
,
4
,
6
,
8
,
0
));
partition
p1
values
in
(
2
,
4
,
6
,
8
,
0
));
insert
into
t1
values
(
NULL
),(
0
),(
1
),(
2
),(
2
),(
4
),(
4
),(
4
),(
8
),(
8
);
insert
into
t1
values
(
NULL
),(
0
),(
1
),(
2
),(
2
),(
4
),(
4
),(
4
),(
8
),(
8
);
...
@@ -119,7 +119,7 @@ select * from t1 where a <= 1;
...
@@ -119,7 +119,7 @@ select * from t1 where a <= 1;
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
list
column
_list
(
a
,
b
)
partition
by
list
column
s
(
a
,
b
)
(
partition
p0
values
in
((
1
,
NULL
),
(
2
,
NULL
),
(
NULL
,
NULL
)),
(
partition
p0
values
in
((
1
,
NULL
),
(
2
,
NULL
),
(
NULL
,
NULL
)),
partition
p1
values
in
((
1
,
1
),
(
2
,
2
)),
partition
p1
values
in
((
1
,
1
),
(
2
,
2
)),
partition
p2
values
in
((
3
,
NULL
),
(
NULL
,
1
)));
partition
p2
values
in
((
3
,
NULL
),
(
NULL
,
1
)));
...
@@ -167,12 +167,12 @@ drop table t1;
...
@@ -167,12 +167,12 @@ drop table t1;
--
error
ER_PARSE_ERROR
--
error
ER_PARSE_ERROR
create
table
t1
(
a
int
)
create
table
t1
(
a
int
)
partition
by
list
column
_list
(
a
)
partition
by
list
column
s
(
a
)
(
partition
p0
values
in
(
2
,
1
),
(
partition
p0
values
in
(
2
,
1
),
partition
p1
values
in
((
4
),
(
NULL
),
(
3
)));
partition
p1
values
in
((
4
),
(
NULL
),
(
3
)));
create
table
t1
(
a
int
)
create
table
t1
(
a
int
)
partition
by
list
column
_list
(
a
)
partition
by
list
column
s
(
a
)
(
partition
p0
values
in
(
2
,
1
),
(
partition
p0
values
in
(
2
,
1
),
partition
p1
values
in
(
4
,
NULL
,
3
));
partition
p1
values
in
(
4
,
NULL
,
3
));
select
partition_method
,
partition_expression
,
partition_description
select
partition_method
,
partition_expression
,
partition_description
...
@@ -189,7 +189,7 @@ show create table t1;
...
@@ -189,7 +189,7 @@ show create table t1;
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
int
,
b
char
(
10
),
c
varchar
(
5
),
d
int
)
create
table
t1
(
a
int
,
b
char
(
10
),
c
varchar
(
5
),
d
int
)
partition
by
range
column
_list
(
a
,
b
,
c
)
partition
by
range
column
s
(
a
,
b
,
c
)
subpartition
by
key
(
c
,
d
)
subpartition
by
key
(
c
,
d
)
subpartitions
3
subpartitions
3
(
partition
p0
values
less
than
(
1
,
'abc'
,
'abc'
),
(
partition
p0
values
less
than
(
1
,
'abc'
,
'abc'
),
...
@@ -209,7 +209,7 @@ select * from t1 where (a = 1 AND b < 'd' AND (c = 'b' OR (c = 'c' AND d = 1)) O
...
@@ -209,7 +209,7 @@ select * from t1 where (a = 1 AND b < 'd' AND (c = 'b' OR (c = 'c' AND d = 1)) O
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
int
,
b
varchar
(
2
),
c
int
)
create
table
t1
(
a
int
,
b
varchar
(
2
),
c
int
)
partition
by
range
column
_list
(
a
,
b
,
c
)
partition
by
range
column
s
(
a
,
b
,
c
)
(
partition
p0
values
less
than
(
1
,
'A'
,
1
),
(
partition
p0
values
less
than
(
1
,
'A'
,
1
),
partition
p1
values
less
than
(
1
,
'B'
,
1
));
partition
p1
values
less
than
(
1
,
'B'
,
1
));
select
partition_method
,
partition_expression
,
partition_description
select
partition_method
,
partition_expression
,
partition_description
...
@@ -221,7 +221,7 @@ select * from t1 where a = 1 AND b <= 'A' and c = 1;
...
@@ -221,7 +221,7 @@ select * from t1 where a = 1 AND b <= 'A' and c = 1;
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
char
,
b
char
,
c
char
)
create
table
t1
(
a
char
,
b
char
,
c
char
)
partition
by
list
column
_list
(
a
)
partition
by
list
column
s
(
a
)
(
partition
p0
values
in
(
'a'
));
(
partition
p0
values
in
(
'a'
));
insert
into
t1
(
a
)
values
(
'a'
);
insert
into
t1
(
a
)
values
(
'a'
);
select
*
from
t1
where
a
=
'a'
;
select
*
from
t1
where
a
=
'a'
;
...
@@ -229,47 +229,47 @@ drop table t1;
...
@@ -229,47 +229,47 @@ drop table t1;
--
error
ER_WRONG_TYPE_COLUMN_VALUE_ERROR
--
error
ER_WRONG_TYPE_COLUMN_VALUE_ERROR
create
table
t1
(
d
time
)
create
table
t1
(
d
time
)
partition
by
range
column
_list
(
d
)
partition
by
range
column
s
(
d
)
(
partition
p0
values
less
than
(
'2000-01-01'
),
(
partition
p0
values
less
than
(
'2000-01-01'
),
partition
p1
values
less
than
(
'2040-01-01'
));
partition
p1
values
less
than
(
'2040-01-01'
));
--
error
ER_FIELD_TYPE_NOT_ALLOWED_AS_PARTITION_FIELD
--
error
ER_FIELD_TYPE_NOT_ALLOWED_AS_PARTITION_FIELD
create
table
t1
(
d
timestamp
)
create
table
t1
(
d
timestamp
)
partition
by
range
column
_list
(
d
)
partition
by
range
column
s
(
d
)
(
partition
p0
values
less
than
(
'2000-01-01'
),
(
partition
p0
values
less
than
(
'2000-01-01'
),
partition
p1
values
less
than
(
'2040-01-01'
));
partition
p1
values
less
than
(
'2040-01-01'
));
--
error
ER_FIELD_TYPE_NOT_ALLOWED_AS_PARTITION_FIELD
--
error
ER_FIELD_TYPE_NOT_ALLOWED_AS_PARTITION_FIELD
create
table
t1
(
d
bit
(
1
))
create
table
t1
(
d
bit
(
1
))
partition
by
range
column
_list
(
d
)
partition
by
range
column
s
(
d
)
(
partition
p0
values
less
than
(
0
),
(
partition
p0
values
less
than
(
0
),
partition
p1
values
less
than
(
1
));
partition
p1
values
less
than
(
1
));
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
range
column
_list
(
a
,
b
)
partition
by
range
column
s
(
a
,
b
)
(
partition
p0
values
less
than
(
maxvalue
,
10
));
(
partition
p0
values
less
than
(
maxvalue
,
10
));
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
d
date
)
create
table
t1
(
d
date
)
partition
by
range
column
_list
(
d
)
partition
by
range
column
s
(
d
)
(
partition
p0
values
less
than
(
'2000-01-01'
),
(
partition
p0
values
less
than
(
'2000-01-01'
),
partition
p1
values
less
than
(
'2009-01-01'
));
partition
p1
values
less
than
(
'2009-01-01'
));
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
d
date
)
create
table
t1
(
d
date
)
partition
by
range
column
_list
(
d
)
partition
by
range
column
s
(
d
)
(
partition
p0
values
less
than
(
'1999-01-01'
),
(
partition
p0
values
less
than
(
'1999-01-01'
),
partition
p1
values
less
than
(
'2000-01-01'
));
partition
p1
values
less
than
(
'2000-01-01'
));
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
d
date
)
create
table
t1
(
d
date
)
partition
by
range
column
_list
(
d
)
partition
by
range
column
s
(
d
)
(
partition
p0
values
less
than
(
'2000-01-01'
),
(
partition
p0
values
less
than
(
'2000-01-01'
),
partition
p1
values
less
than
(
'3000-01-01'
));
partition
p1
values
less
than
(
'3000-01-01'
));
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
range
column
_list
(
a
,
b
)
partition
by
range
column
s
(
a
,
b
)
(
partition
p2
values
less
than
(
99
,
99
),
(
partition
p2
values
less
than
(
99
,
99
),
partition
p1
values
less
than
(
99
,
999
));
partition
p1
values
less
than
(
99
,
999
));
...
@@ -284,21 +284,21 @@ drop table t1;
...
@@ -284,21 +284,21 @@ drop table t1;
--
error
ER_PARSE_ERROR
--
error
ER_PARSE_ERROR
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
list
column
_list
(
a
,
b
)
partition
by
list
column
s
(
a
,
b
)
(
partition
p0
values
in
((
maxvalue
,
maxvalue
)));
(
partition
p0
values
in
((
maxvalue
,
maxvalue
)));
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
range
column
_list
(
a
,
b
)
partition
by
range
column
s
(
a
,
b
)
(
partition
p0
values
less
than
(
maxvalue
,
maxvalue
));
(
partition
p0
values
less
than
(
maxvalue
,
maxvalue
));
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
int
)
create
table
t1
(
a
int
)
partition
by
list
column
_list
(
a
)
partition
by
list
column
s
(
a
)
(
partition
p0
values
in
(
0
));
(
partition
p0
values
in
(
0
));
select
partition_method
from
information_schema
.
partitions
where
table_name
=
't1'
;
select
partition_method
from
information_schema
.
partitions
where
table_name
=
't1'
;
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
char
(
6
))
create
table
t1
(
a
char
(
6
))
partition
by
range
column
_list
(
a
)
partition
by
range
column
s
(
a
)
(
partition
p0
values
less
than
(
'H23456'
),
(
partition
p0
values
less
than
(
'H23456'
),
partition
p1
values
less
than
(
'M23456'
));
partition
p1
values
less
than
(
'M23456'
));
insert
into
t1
values
(
'F23456'
);
insert
into
t1
values
(
'F23456'
);
...
@@ -307,28 +307,28 @@ drop table t1;
...
@@ -307,28 +307,28 @@ drop table t1;
--
error
1054
--
error
1054
create
table
t1
(
a
char
(
6
))
create
table
t1
(
a
char
(
6
))
partition
by
range
column
_list
(
a
)
partition
by
range
column
s
(
a
)
(
partition
p0
values
less
than
(
H23456
),
(
partition
p0
values
less
than
(
H23456
),
partition
p1
values
less
than
(
M23456
));
partition
p1
values
less
than
(
M23456
));
--
error
ER_RANGE_NOT_INCREASING_ERROR
--
error
ER_RANGE_NOT_INCREASING_ERROR
create
table
t1
(
a
char
(
6
))
create
table
t1
(
a
char
(
6
))
partition
by
range
column
_list
(
a
)
partition
by
range
column
s
(
a
)
(
partition
p0
values
less
than
(
23456
),
(
partition
p0
values
less
than
(
23456
),
partition
p1
values
less
than
(
23456
));
partition
p1
values
less
than
(
23456
));
--
error
1064
--
error
1064
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
range
column
_list
(
a
,
b
)
partition
by
range
column
s
(
a
,
b
)
(
partition
p0
values
less
than
(
10
));
(
partition
p0
values
less
than
(
10
));
--
error
ER_PARTITION_COLUMN_LIST_ERROR
--
error
ER_PARTITION_COLUMN_LIST_ERROR
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
range
column
_list
(
a
,
b
)
partition
by
range
column
s
(
a
,
b
)
(
partition
p0
values
less
than
(
1
,
1
,
1
);
(
partition
p0
values
less
than
(
1
,
1
,
1
);
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
range
column
_list
(
a
,
b
)
partition
by
range
column
s
(
a
,
b
)
(
partition
p0
values
less
than
(
1
,
0
),
(
partition
p0
values
less
than
(
1
,
0
),
partition
p1
values
less
than
(
2
,
maxvalue
),
partition
p1
values
less
than
(
2
,
maxvalue
),
partition
p2
values
less
than
(
3
,
3
),
partition
p2
values
less
than
(
3
,
3
),
...
@@ -340,7 +340,7 @@ insert into t1 values (0,1),(1,1),(2,1),(3,1),(3,4),(4,9),(9,1);
...
@@ -340,7 +340,7 @@ insert into t1 values (0,1),(1,1),(2,1),(3,1),(3,4),(4,9),(9,1);
select
*
from
t1
;
select
*
from
t1
;
alter
table
t1
alter
table
t1
partition
by
range
column
_list
(
b
,
a
)
partition
by
range
column
s
(
b
,
a
)
(
partition
p0
values
less
than
(
1
,
2
),
(
partition
p0
values
less
than
(
1
,
2
),
partition
p1
values
less
than
(
3
,
3
),
partition
p1
values
less
than
(
3
,
3
),
partition
p2
values
less
than
(
9
,
5
));
partition
p2
values
less
than
(
9
,
5
));
...
@@ -374,7 +374,7 @@ select * from t1 where b < 4;
...
@@ -374,7 +374,7 @@ select * from t1 where b < 4;
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
int
,
b
int
)
create
table
t1
(
a
int
,
b
int
)
partition
by
list
column
_list
(
a
,
b
)
partition
by
list
column
s
(
a
,
b
)
subpartition
by
hash
(
b
)
subpartition
by
hash
(
b
)
subpartitions
2
subpartitions
2
(
partition
p0
values
in
((
0
,
0
),
(
1
,
1
)),
(
partition
p0
values
in
((
0
,
0
),
(
1
,
1
)),
...
@@ -384,7 +384,7 @@ insert into t1 values (1000,1000);
...
@@ -384,7 +384,7 @@ insert into t1 values (1000,1000);
drop
table
t1
;
drop
table
t1
;
create
table
t1
(
a
char
,
b
char
,
c
char
)
create
table
t1
(
a
char
,
b
char
,
c
char
)
partition
by
range
column
_list
(
a
,
b
,
c
)
partition
by
range
column
s
(
a
,
b
,
c
)
(
partition
p0
values
less
than
(
'a'
,
'b'
,
'c'
));
(
partition
p0
values
less
than
(
'a'
,
'b'
,
'c'
));
alter
table
t1
add
partition
alter
table
t1
add
partition
(
partition
p1
values
less
than
(
'b'
,
'c'
,
'd'
));
(
partition
p1
values
less
than
(
'b'
,
'c'
,
'd'
));
...
...
mysql-test/t/partition_column_prune.test
View file @
40496deb
...
@@ -8,7 +8,7 @@ drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
...
@@ -8,7 +8,7 @@ drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
--
enable_warnings
--
enable_warnings
create
table
t1
(
a
char
,
b
char
,
c
char
)
create
table
t1
(
a
char
,
b
char
,
c
char
)
partition
by
range
column
_list
(
a
,
b
,
c
)
partition
by
range
column
s
(
a
,
b
,
c
)
(
partition
p0
values
less
than
(
'a'
,
'b'
,
'c'
));
(
partition
p0
values
less
than
(
'a'
,
'b'
,
'c'
));
insert
into
t1
values
(
'a'
,
NULL
,
'd'
);
insert
into
t1
values
(
'a'
,
NULL
,
'd'
);
explain
partitions
select
*
from
t1
where
a
=
'a'
AND
c
=
'd'
;
explain
partitions
select
*
from
t1
where
a
=
'a'
AND
c
=
'd'
;
...
@@ -16,7 +16,7 @@ select * from t1 where a = 'a' AND c = 'd';
...
@@ -16,7 +16,7 @@ select * from t1 where a = 'a' AND c = 'd';
drop
table
t1
;
drop
table
t1
;
## COLUMN_LIST partition pruning tests
## COLUMN_LIST partition pruning tests
create
table
t1
(
a
int
not
null
)
partition
by
range
column
_list
(
a
)
(
create
table
t1
(
a
int
not
null
)
partition
by
range
column
s
(
a
)
(
partition
p0
values
less
than
(
10
),
partition
p0
values
less
than
(
10
),
partition
p1
values
less
than
(
20
),
partition
p1
values
less
than
(
20
),
partition
p2
values
less
than
(
30
),
partition
p2
values
less
than
(
30
),
...
@@ -46,7 +46,7 @@ explain partitions select * from t2 where a > 35 and a < 45;
...
@@ -46,7 +46,7 @@ explain partitions select * from t2 where a > 35 and a < 45;
drop
table
t1
,
t2
;
drop
table
t1
,
t2
;
create
table
t1
(
a
int
not
null
,
b
int
not
null
)
create
table
t1
(
a
int
not
null
,
b
int
not
null
)
partition
by
range
column
_list
(
a
,
b
)
(
partition
by
range
column
s
(
a
,
b
)
(
partition
p01
values
less
than
(
2
,
10
),
partition
p01
values
less
than
(
2
,
10
),
partition
p02
values
less
than
(
2
,
20
),
partition
p02
values
less
than
(
2
,
20
),
partition
p03
values
less
than
(
2
,
30
),
partition
p03
values
less
than
(
2
,
30
),
...
...
mysql-test/t/partition_innodb.test
View file @
40496deb
...
@@ -10,7 +10,7 @@ drop table if exists t1;
...
@@ -10,7 +10,7 @@ drop table if exists t1;
#
#
create
table
t1
(
a
varchar
(
5
))
create
table
t1
(
a
varchar
(
5
))
engine
=
memory
engine
=
memory
partition
by
range
column
_list
(
a
)
partition
by
range
column
s
(
a
)
(
partition
p0
values
less
than
(
'm'
),
(
partition
p0
values
less
than
(
'm'
),
partition
p1
values
less
than
(
'za'
));
partition
p1
values
less
than
(
'za'
));
insert
into
t1
values
(
'j'
);
insert
into
t1
values
(
'j'
);
...
@@ -19,7 +19,7 @@ drop table t1;
...
@@ -19,7 +19,7 @@ drop table t1;
create
table
t1
(
a
varchar
(
5
))
create
table
t1
(
a
varchar
(
5
))
engine
=
myisam
engine
=
myisam
partition
by
range
column
_list
(
a
)
partition
by
range
column
s
(
a
)
(
partition
p0
values
less
than
(
'm'
),
(
partition
p0
values
less
than
(
'm'
),
partition
p1
values
less
than
(
'za'
));
partition
p1
values
less
than
(
'za'
));
insert
into
t1
values
(
'j'
);
insert
into
t1
values
(
'j'
);
...
@@ -28,7 +28,7 @@ drop table t1;
...
@@ -28,7 +28,7 @@ drop table t1;
create
table
t1
(
a
varchar
(
5
))
create
table
t1
(
a
varchar
(
5
))
engine
=
innodb
engine
=
innodb
partition
by
range
column
_list
(
a
)
partition
by
range
column
s
(
a
)
(
partition
p0
values
less
than
(
'm'
),
(
partition
p0
values
less
than
(
'm'
),
partition
p1
values
less
than
(
'za'
));
partition
p1
values
less
than
(
'za'
));
insert
into
t1
values
(
'j'
);
insert
into
t1
values
(
'j'
);
...
...
mysql-test/t/partition_range.test
View file @
40496deb
...
@@ -63,7 +63,7 @@ drop table t1;
...
@@ -63,7 +63,7 @@ drop table t1;
#
#
--
error
1064
--
error
1064
create
table
t1
(
a
int
,
b
char
(
20
))
create
table
t1
(
a
int
,
b
char
(
20
))
partition
by
range
column
_list
(
a
,
b
)
partition
by
range
column
s
(
a
,
b
)
(
partition
p0
values
less
than
(
1
));
(
partition
p0
values
less
than
(
1
));
--
error
ER_TOO_MANY_VALUES_ERROR
--
error
ER_TOO_MANY_VALUES_ERROR
...
@@ -77,7 +77,7 @@ partition by range(a)
...
@@ -77,7 +77,7 @@ partition by range(a)
(
partition
p0
values
less
than
(
1
,
"b"
));
(
partition
p0
values
less
than
(
1
,
"b"
));
create
table
t1
(
a
int
,
b
char
(
20
))
create
table
t1
(
a
int
,
b
char
(
20
))
partition
by
range
column
_list
(
b
)
partition
by
range
column
s
(
b
)
(
partition
p0
values
less
than
(
"b"
));
(
partition
p0
values
less
than
(
"b"
));
drop
table
t1
;
drop
table
t1
;
...
...
sql/lex.h
View file @
40496deb
...
@@ -119,7 +119,6 @@ static SYMBOL symbols[] = {
...
@@ -119,7 +119,6 @@ static SYMBOL symbols[] = {
{
"COLUMN"
,
SYM
(
COLUMN_SYM
)},
{
"COLUMN"
,
SYM
(
COLUMN_SYM
)},
{
"COLUMN_NAME"
,
SYM
(
COLUMN_NAME_SYM
)},
{
"COLUMN_NAME"
,
SYM
(
COLUMN_NAME_SYM
)},
{
"COLUMNS"
,
SYM
(
COLUMNS
)},
{
"COLUMNS"
,
SYM
(
COLUMNS
)},
{
"COLUMN_LIST"
,
SYM
(
COLUMN_LIST_SYM
)},
{
"COMMENT"
,
SYM
(
COMMENT_SYM
)},
{
"COMMENT"
,
SYM
(
COMMENT_SYM
)},
{
"COMMIT"
,
SYM
(
COMMIT_SYM
)},
{
"COMMIT"
,
SYM
(
COMMIT_SYM
)},
{
"COMMITTED"
,
SYM
(
COMMITTED_SYM
)},
{
"COMMITTED"
,
SYM
(
COMMITTED_SYM
)},
...
...
sql/opt_range.cc
View file @
40496deb
...
@@ -3251,7 +3251,7 @@ int find_used_partitions(PART_PRUNE_PARAM *ppar, SEL_ARG *key_tree)
...
@@ -3251,7 +3251,7 @@ int find_used_partitions(PART_PRUNE_PARAM *ppar, SEL_ARG *key_tree)
/*
/*
We need to call the interval mapper if we have a condition which
We need to call the interval mapper if we have a condition which
makes sense to prune on. In the example of
a COLUMN_LIST
on a and
makes sense to prune on. In the example of
COLUMNS
on a and
b it makes sense if we have a condition on a, or conditions on
b it makes sense if we have a condition on a, or conditions on
both a and b. If we only have conditions on b it might make sense
both a and b. If we only have conditions on b it might make sense
but this is a harder case we will solve later. For the harder case
but this is a harder case we will solve later. For the harder case
...
...
sql/sql_partition.cc
View file @
40496deb
...
@@ -68,7 +68,7 @@ const LEX_STRING partition_keywords[]=
...
@@ -68,7 +68,7 @@ const LEX_STRING partition_keywords[]=
{
C_STRING_WITH_LEN
(
"KEY"
)
},
{
C_STRING_WITH_LEN
(
"KEY"
)
},
{
C_STRING_WITH_LEN
(
"MAXVALUE"
)
},
{
C_STRING_WITH_LEN
(
"MAXVALUE"
)
},
{
C_STRING_WITH_LEN
(
"LINEAR "
)
},
{
C_STRING_WITH_LEN
(
"LINEAR "
)
},
{
C_STRING_WITH_LEN
(
" COLUMN
_LIST
"
)
}
{
C_STRING_WITH_LEN
(
" COLUMN
S
"
)
}
};
};
static
const
char
*
part_str
=
"PARTITION"
;
static
const
char
*
part_str
=
"PARTITION"
;
static
const
char
*
subpart_str
=
"SUBPARTITION"
;
static
const
char
*
subpart_str
=
"SUBPARTITION"
;
...
@@ -6925,7 +6925,7 @@ void make_used_partitions_str(partition_info *part_info, String *parts_str)
...
@@ -6925,7 +6925,7 @@ void make_used_partitions_str(partition_info *part_info, String *parts_str)
(1) is applicable for "PARTITION BY <RANGE|LIST>(func(t.field))", where
(1) is applicable for "PARTITION BY <RANGE|LIST>(func(t.field))", where
func is a monotonic function.
func is a monotonic function.
(2) is applicable for "PARTITION BY <RANGE|LIST> COLUMN
_LIST
(field_list)
(2) is applicable for "PARTITION BY <RANGE|LIST> COLUMN
S
(field_list)
(3) is applicable for
(3) is applicable for
"[SUB]PARTITION BY <any-partitioning-type>(any_func(t.integer_field))"
"[SUB]PARTITION BY <any-partitioning-type>(any_func(t.integer_field))"
...
@@ -7624,7 +7624,7 @@ uint32 get_next_partition_id_range(PARTITION_ITERATOR* part_iter)
...
@@ -7624,7 +7624,7 @@ uint32 get_next_partition_id_range(PARTITION_ITERATOR* part_iter)
DESCRIPTION
DESCRIPTION
This implementation of PARTITION_ITERATOR::get_next() is special for
This implementation of PARTITION_ITERATOR::get_next() is special for
LIST partitioning: it enumerates partition ids in
LIST partitioning: it enumerates partition ids in
part_info->list_array[i] (list_col_array[i] for COLUMN
_LIST
LIST
part_info->list_array[i] (list_col_array[i] for COLUMN
S
LIST
partitioning) where i runs over [min_idx, max_idx] interval.
partitioning) where i runs over [min_idx, max_idx] interval.
The function conforms to partition_iter_func type.
The function conforms to partition_iter_func type.
...
...
sql/sql_yacc.yy
View file @
40496deb
...
@@ -611,7 +611,6 @@ bool my_yyoverflow(short **a, YYSTYPE **b, ulong *yystacksize);
...
@@ -611,7 +611,6 @@ bool my_yyoverflow(short **a, YYSTYPE **b, ulong *yystacksize);
%token COLLATE_SYM /* SQL-2003-R */
%token COLLATE_SYM /* SQL-2003-R */
%token COLLATION_SYM /* SQL-2003-N */
%token COLLATION_SYM /* SQL-2003-N */
%token COLUMNS
%token COLUMNS
%token COLUMN_LIST_SYM
%token COLUMN_SYM /* SQL-2003-R */
%token COLUMN_SYM /* SQL-2003-R */
%token COLUMN_NAME_SYM /* SQL-2003-N */
%token COLUMN_NAME_SYM /* SQL-2003-N */
%token COMMENT_SYM
%token COMMENT_SYM
...
@@ -4121,7 +4120,7 @@ part_field_item:
...
@@ -4121,7 +4120,7 @@ part_field_item:
;
;
part_column_list:
part_column_list:
COLUMN
_LIST_SYM
'(' part_field_list ')'
COLUMN
S
'(' part_field_list ')'
{
{
partition_info *part_info= Lex->part_info;
partition_info *part_info= Lex->part_info;
part_info->column_list= TRUE;
part_info->column_list= TRUE;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment