MySQL从5.1版开始分区表,但是只能针对整数型的字段,对于经常使用的按时间分区,只能变通实现,比如使用YEAR()函数和TO_DAYS()函数:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
--使用YEAR按年分成三个区
ALTER
TABLE
test
PARTITION
BY
RANGE(
YEAR
(
Time
))
(
PARTITION p0
VALUES
LESS THAN (2012),
PARTITION p1
VALUES
LESS THAN (2013),
PARTITION p2
VALUES
LESS THAN (MAXVALUE)
)
--使用TO_DAYS可以精确到天
ALTER
TABLE
test
PARTITION
BY
RANGE(TO_DAYS(
Time
))
(
PARTITION p0
VALUES
LESS THAN (TO_DAYS(
'2013-1-1'
)),
PARTITION p1
VALUES
LESS THAN (TO_DAYS(
'2013-5-1'
)),
PARTITION p2
VALUES
LESS THAN (MAXVALUE)
)
|
实际使用过程中,分区的判断经常不准,用explain partitions ……可以看到经常是不相关的分区也扫描了,原因未知。
从5.5版开始,这个功能终于改进了,可以直接按datetime字段分区了。语法小有改变:
1
2
3
4
5
6
7
8
|
--可以随意定义切分方式,很方便
ALTER
TABLE
test
PARTITION
BY
RANGE COLUMNS(
Time
)
(
PARTITION p0
VALUES
LESS THAN (
'2013-1-1'
),
PARTITION p1
VALUES
LESS THAN (
'2013-5-1 19:00'
),
PARTITION p2
VALUES
LESS THAN (MAXVALUE)
)
|
试了一下没有再发现分区识别不准的情况。
本文转自 BoyTNT 51CTO博客,原文链接:http://blog.51cto.com/boytnt/1305884,如需转载请自行联系原作者