更新时间:2022-02-22 GMT+08:00
DD算法
适用场景
DD 适用于按日期的天数进行分表,分表的表数就是日期的天数。
使用说明
- 拆分键的类型必须是 DATE / DATETIME / TIMESTAMP 其中之一。
- 只能作为分表函数使用,但不能作为分库函数。
路由方式
根据拆分键的时间值的日期的天数进行取余运算并得到分表下标。
例如:2019-1-15,当根据分库建确定分库后,确定分表的计算方式是:一个月的第几天mod分表数,即:15 mod 31 = 15。
算法计算方式
条件 |
计算方式 |
举例 |
---|---|---|
无 |
分表路由结果 = 分表拆分键值 % 分表数 |
分表拆分键值 :2019-1-15 分表:15 % 31 = 15 |
建表语法
create table test_dd_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(id) tbpartition by DD(create_time) tbpartitions 31;
注意事项
按 DD 进行分表,由于一个月的中日期(DATE_OF_MONTH)的取值范围是1~31,所以各分库的分表数不能超过 31 张分表。
父主题: 拆分算法使用说明