生成日期维度表

1、创建表
DROP TABLE IF EXISTS sys_date;
CREATE TABLE IF NOT EXISTS sys_date (
date VARCHAR ( 255 ) DEFAULT NULL,
month VARCHAR ( 255 ) DEFAULT NULL,
day VARCHAR ( 255 ) DEFAULT NULL,
quarter VARCHAR ( 255 ) DEFAULT NULL,
year VARCHAR ( 255 ) DEFAULT NULL
) ENGINE = INNODB DEFAULT CHARSET = utf8;

2、建立日期维度数据生成的存储过程
CREATE DEFINER=root@% PROCEDURE pre_populate_date(IN start_dt date, IN end_dt date)
BEGIN
WHILE start_dt <= end_dt DO
INSERT INTO sys_date(date_sk, date, month, quarter, year, day)
VALUES
( NULL, start_dt, MONTH(start_dt), QUARTER(start_dt), YEAR (start_dt), DAY(start_dt));
SET start_dt = adddate( start_dt, 1 );
END WHILE;
COMMIT;
END

3、执行
SET FOREIGN_KEY_CHECKS = 0;
TRUNCATE TABLE sys_date;
CALL pre_populate_date ( ‘2021-01-01’, ‘2030-12-31’ );
SET FOREIGN_KEY_CHECKS = 1;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值