更新时间:2023-07-25 GMT+08:00

WEEK按星期哈希

适用场景

WEEK适用于按周数的日期目进行分表,分表的表名的下标分别对应一周中的各个日期(星期一到星期天)。

使用说明

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

路由方式

根据拆分键的时间值所对应的一周之中的日期进行取余运算并得到分表下标。

例如:2019-1-15,当根据分库建确定分库后,确定分表的计算方式是:一周的第几天mod分表数,即:3 mod 7 = 3。

您可以使用如下SQL查询指定日期的工作日索引(0 = 星期一,1 = 星期二,... 6 = 星期日)。

mysql> SELECT WEEKDAY('2019-01-15'); 
              -> 1

上述SQL返回值为1,表示2019-01-15是周二,因为周日为一周中的第一天,所以周二则为一周中的第三天。

算法计算方式

表1 算法举例

条件

算法

举例

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

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

分表:3 % 7= 3

建表语法

create table test_week_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 WEEK(create_time) tbpartitions 7;

注意事项

由于一周共有7天,当按WEEK进行分表时,所以各分库的分表数不能超过7张。