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

前端之家收集整理的这篇文章主要介绍了在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
        ;
原文链接:https://www.f2er.com/postgresql/192899.html

猜你在找的Postgre SQL相关文章