微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在PostgreSQL中生成两个日期之间的时间序列

我有一个这样的查询,很好地在两个给定日期之间生成一系列日期:
select date '2004-03-07' + j - i as AllDate 
from generate_series(0,extract(doy from date '2004-03-07')::int - 1) as i,generate_series(0,extract(doy from date '2004-08-16')::int - 1) as j

它在2004-03-07和2004-08-16之间产生162个日期,这就是我想要的。但是这个代码的问题是,当两个日期来自不同的年份时,例如当我尝试2007-02-01和2008-04-01时,它不会给出正确的答案。任何人有任何想法如何推广它或替代品?

可以在没有转换为/从int的情况下完成(而是转换为/从时间戳)
SELECT date_trunc('day',dd):: date
FROM generate_series
        ( '2007-02-01'::timestamp,'2008-04-01'::timestamp,'1 day'::interval) dd
        ;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐