mysql datetime 分区_在MySQL分区表中支持datetime类型的列

MySQL从5.1版开始分区表,但是只能针对整数型的字段,对于经常使用的按时间分区,只能变通实现,比如使用YEAR()函数和TO_DAYS()函数:--使用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字段分区了。语法小有改变:--可以随意定义切分方式,很方便

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)

)

试了一下没有再发现分区识别不准的情况。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值