以 15 分钟的间隔生成系列,但每隔一周跳过一次
generate series at 15 minute interval but skip every other week
我需要 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
谢谢
您需要两个 循环 - 一个用于一周的第一天,另一个用于一周内的 15 分钟间隔。在 SQL 中,cross join 用于实现 嵌套循环:
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
我需要 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
谢谢
您需要两个 循环 - 一个用于一周的第一天,另一个用于一周内的 15 分钟间隔。在 SQL 中,cross join 用于实现 嵌套循环:
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