全部产品
云市场
云游戏

WEEK

更新时间:2020-08-03 15:40:35

使用要求

  • 拆分键的类型必须是DATE、DATETIME或TIMESTAMP其中之一。
  • 只能作为分表函数使用,但不能作为分库函数。
  • PolarDB-X实例的版本必须是5.1.28-1320920及其以上的版本。PolarDB-X版本说明请参见版本说明

路由方式

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

使用场景

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

使用示例

假设先按ID对用户进行分库,再需要对create_time列按周进行分表,并且每周7天(星期一到星期天)各对应一张物理表,则应该使用如下的建表DDL:

  1. create table test_week_tb (
  2. id int,
  3. name varchar(30) DEFAULT NULL,
  4. create_time datetime DEFAULT NULL,
  5. primary key(id)
  6. ) ENGINE=InnoDB DEFAULT CHARSET=utf8
  7. dbpartition by HASH(name)
  8. tbpartition by WEEK(create_time) tbpartitions 7;

注意事项

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