MMDD按月日哈希
适用场景
MMDD适用于按一年的天数(即一年中日期)进行分表,分表的表名的下标就是一年中的第几天,一年最多366天。
使用说明
- 拆分键的类型必须是DATE/DATETIME/TIMESTAMP其中之一。
- 只能作为分表函数使用,但不能作为分库函数。
路由方式
根据拆分键的时间值所对应的日期在一年中对应的天数,然后进行取余运算并得到分表下标。
例如:2019-1-15,当根据分库键确定分库后,确定分表的计算方式是:一年的第几天mod分表数,即:15 mod 366 = 15; 2019-1-15是一年的第15天。
算法计算方式
条件 |
算法 |
举例 |
---|---|---|
无 |
分表路由结果 = 分表拆分键值 % 分表数 |
分表拆分键值 :2019-1-15 分表:15 % 366= 15 |
建表语法
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 MOD_HASH(name) tbpartition by MMDD(create_time) tbpartitions 366;
注意事项
由于一年最多只有 366 天,当按 MMDD 进行分表时,所以各个分库的分表数目不能超过 366 张分表。