MMDD
使用要求
- 拆分键的类型必须是 DATE / DATETIME / TIMESTAMP 其中之一。
- 只能作为分表函数使用,但不能作为分库函数。
- DRDS 实例的版本必须是 5.1.28-1320920 及其以上的版本。DRDS 版本说明请参考文档版本说明。
路由方式
根据分库键的时间值所对应的日期在一年中对应的天数
,然后进行取余运算并得到分表下标。
使用场景
MMDD 适用于按一年的天数(即一年中日期)进行分表,分表的表名的下标就是一年中的第某天,一年最多 366 天。
使用示例
假设先按 id 对用户进行分库,然后需要对 create_time 列按日期(时间的月份与日期)进行建表,并且一年中每一天的日期都能对应一张物理表,则应该使用如下的建表 DDL:
create table test_mmdd_tb (
id int,
name varchar(30) DEFAULT NULL,
create_time datetime DEFAULT NULL,
primary key(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
dbpartition by HASH(name)
tbpartition by MMDD(create_time) tbpartitions 366;
注意事项
由于一年最多只有 366 天,当按 MMDD 进行分表时,所以各个分库的分表数目不能超过 366 张分表。
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。
评论