首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >生成15分钟间隔的序列,但每隔一周跳过一次。

生成15分钟间隔的序列,但每隔一周跳过一次。
EN

Stack Overflow用户
提问于 2017-10-20 23:23:06
回答 1查看 1.2K关注 0票数 1

我需要间隔15分钟的generate_series。但我需要它每隔一周跳一次。

这就是我到目前为止所得到的,每隔15分钟一次,,但每隔一周不省略一次。

代码语言:javascript
运行
复制
select i from generate_series('2017-01-01', '2017-12-31', '15 minutes'::interval) as g(i);

我还可以每隔一周generate_series一次:

代码语言:javascript
运行
复制
select i from generate_series('2017-12-31', '2017-01-01', '-2 week'::interval) as g(i)

只是需要帮助把两者结合起来:间隔15分钟,但每隔一周跳一次。

抽样结果:

代码语言:javascript
运行
复制
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

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-10-20 23:41:35

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

代码语言:javascript
运行
复制
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
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46858564

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档