在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
        ;

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...