xiaozhuaia 发表于 2018-10-1 13:54:10

在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)
  
)
  试了一下没有再发现分区识别不准的情况。


页: [1]
查看完整版本: 在MySQL分区表中支持datetime类型的列