全部产品
存储与CDN 数据库 安全 应用服务 数加·人工智能 数加·大数据基础服务 互联网中间件 视频服务 开发者工具 解决方案 物联网 钉钉智能硬件
分布式关系型数据库 DRDS

WEEK

更新时间:2017-12-11 21:28:05

使用要求

  • 拆分键的类型必须是 DATE / DATETIME / TIMESTAMP 其中之一。

  • 只能作为分表函数使用,但不能作为分库函数。

  • DRDS 实例的版本必须是 5.1.28-1320920 及其以上的版本。DRDS 版本说明请参考文档版本说明

路由方式

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

使用场景

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

使用示例

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

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 张。

本文导读目录