以15分钟的间隔生成系列,但每隔一周跳过一次

时间:2017-10-20 23:23:07

标签: sql postgresql intervals generate-series

我需要generate_series,间隔15分钟。需要注意的是,我需要每隔一周跳过一次。

这就是我到目前为止以15分钟的间隔获得系列不是每隔一周就省略

select i from generate_series('2017-01-01', '2017-12-31', '15 minutes'::interval) as g(i);

我每隔一周也能generate_series

select i from generate_series('2017-12-31', '2017-01-01', '-2 week'::interval) as g(i)

只需要帮助将两者放在一起:得到15分钟的间隔,但每隔一周跳过

样本结果:

timestamp
----------------------
2017-01-01 00:00:00+00
2017-01-01 00:15:00+00
2017-01-01 00:30:00+00
...
2017-01-15 00:45:00+00
2017-01-15 01:00:00+00
2017-01-15 01:15:00+00
...
2017-01-29 00:30:00+00
2017-01-29 00:45:00+00
2017-01-29 01:00:00+00

由于

1 个答案:

答案 0 :(得分:1)

你需要两个循环 - 一个用于一周的第一天,另一个用于一周内的15分钟。在SQL中,交叉连接用于实现嵌套循环:

select tstamp
from generate_series('2017-01-01', '2017-12-31', '2 week'::interval) as start_of_week
cross join generate_series(start_of_week::date, start_of_week::date+ '1 week'::interval, '15 min'::interval) as tstamp