-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdate_spine_generator_redshift.sql
49 lines (43 loc) · 1.23 KB
/
date_spine_generator_redshift.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
-- This query generates a row for every date between 2016-01-01 and 2025-01-01
with
numbers_table as (
select
p0.n
+ p1.n*2
+ p2.n * POWER(2,2)
+ p3.n * POWER(2,3)
+ p4.n * POWER(2,4)
+ p5.n * POWER(2,5)
+ p6.n * POWER(2,6)
+ p7.n * POWER(2,7)
+ p8.n * POWER(2,8)
+ p9.n * POWER(2,9)
+ p10.n * POWER(2,10)
+ p11.n * POWER(2,11)
as n
from
(SELECT 0 as n UNION SELECT 1) p0,
(SELECT 0 as n UNION SELECT 1) p1,
(SELECT 0 as n UNION SELECT 1) p2,
(SELECT 0 as n UNION SELECT 1) p3,
(SELECT 0 as n UNION SELECT 1) p4,
(SELECT 0 as n UNION SELECT 1) p5,
(SELECT 0 as n UNION SELECT 1) p6,
(SELECT 0 as n UNION SELECT 1) p7,
(SELECT 0 as n UNION SELECT 1) p8,
(SELECT 0 as n UNION SELECT 1) p9,
(SELECT 0 as n UNION SELECT 1) p10,
(SELECT 0 as n UNION SELECT 1) p11
),
date_table as (
select
('2025-01-01'::date - row_number() over (order by true))::date as series
from numbers_table
order by series asc
)
select
series as series_date
, date_trunc('month', series) as series_month
, date_trunc('week', series) as series_week
from date_table
where series >= '2016-01-01'