美文网首页
mysql创建时间维度表

mysql创建时间维度表

作者: onwingsofsong | 来源:发表于2019-03-11 11:31 被阅读0次

DROP TABLE IF EXISTS `T`;

CREATE TABLE `T` (

`n` int(11)

);

INSERT INTO `T`(n) SELECT @row := @row + 1 as row FROM

(select 0 union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) t,

(select 0 union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) t2,

(select 0 union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) t3,

(select 0 union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) t4,

(select 0 union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) t5,

(select 0 union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) t6,

(SELECT @row:=0) t7;

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

SET @d1 = "2012-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

;

相关文章

网友评论

      本文标题:mysql创建时间维度表

      本文链接:https://www.haomeiwen.com/subject/bkpvpqtx.html