更新时间:2022-02-22 GMT+08:00

MM算法

适用场景

MM 适用于按月份数进行分表,分表的表名就是月份数。

使用说明

  • 拆分键的类型必须是 DATE / DATETIME / TIMESTAMP 其中之一。
  • 只能作为分表函数使用,但不能作为分库函数。

路由方式

根据拆分键的时间值的月份数进行取余运算并得到分表下标。

例如:2019-1-15,当根据分库键确定分库后,确定分表的计算方式是:月份mod分表数,即:1 mod 12 = 1。

算法计算方式

表1 算法举例

条件

计算方式

举例

分表路由结果 = 分表拆分键值 % 分表数

分表拆分键值 :2019-1-15

分表:1 % 12 = 1

建表语法

create table test_mm_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 MM(create_time) tbpartitions 12;

注意事项

按 MM 进行分表,由于一年的月份只有 12 个月,所以各分库的分表数不能超过 12 张分表。