mysql创建时间维度的sql脚本

mysql创建时间维度sql脚本
其中d0是开始时间,d1是结束时间
T是万能的表,只需满足T表的记录数量大于所插入的时间行数即可.

# time span  

SET @d0 = "2014-01-01";  

SET @d1 = "2016-12-31";  



SET @date = date_sub(@d0, interval 1 day);  



# set up the time dimension table  

DROP TABLE IF EXISTS time_dimension;  

CREATE TABLE `time_dimension` (  

  `date` date DEFAULT NULL,  

  `id` int NOT NULL,  

  `y` smallint DEFAULT NULL,  

  `m` smallint DEFAULT NULL,  

  `d` smallint DEFAULT NULL,  

  `yw` smallint DEFAULT NULL,  

  `w` smallint DEFAULT NULL,  

  `q` smallint DEFAULT NULL,  

  `wd` smallint DEFAULT NULL,  

  `m_name`  char(10) DEFAULT NULL,  

  `wd_name` char(10) DEFAULT NULL,  

  PRIMARY KEY (`id`)  

);  



# populate the table with dates  

INSERT INTO time_dimension  

SELECT @date := date_add(@date, interval 1 day) as date,  

    # integer ID that allowsimmediate understanding  

    date_format(@date, "%Y%m%d")as id,  

    year(@date) as y,  

    month(@date) as m,  

    day(@date) as d,  

    date_format(@date, "%x")as yw,  

    week(@date, 3) as w,  

    quarter(@date) as q,  

    weekday(@date)+1 as wd,  

    monthname(@date) as m_name,  

    dayname(@date) as wd_name  

FROM T  

WHERE date_add(@date, interval 1 day) <= @d1  

ORDER BY date  
;  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值