pgsql需要使用函数如下
使用date_trunc()函数找到指定月第一天
select date_trunc('month','2023-01-06'::date) // 月第一天
select date_trunc('day','2023-01-06'::date) // 某一天的日期
计算每个月的最后一天:对该日期先加一个月在减一天就能得到你传给的日期的最后一天日期
select date_trunc('month','2023-01-06'::date) + interval '1 month' - interval '1 day';
然后在使用generate_series()函数
select date(t) d
from generate_series('2023-02-21'::date,'2023-06-09'::date,'1 month') t
select date(t) d
from generate_series('2023-02-21'::date,'2023-06-09'::date,'1 day') t
你发现这样写不能得到自己的期望结果,有些日期不准确。
最后generate_series()函数结合date_trunc()函数就能达到期望结果:
SELECT
to_char((select date_trunc('day',date(t))+interval '1 day'- interval '1 day'),'yyyy.MM.dd') as time1
FROM
generate_series(cast('2021-06-30' as date),cast('2022-05-31' as date),'1 day') t
ORDER BY time1
select to_char((select date_trunc('month',date(t))+interval '1 month'- interval '1 day'),'yyyy-MM-dd') date
from generate_series('2021-06-30'::date,'2022-05-31'::date,'1 month') t
######然后再将日期与你需要查询的表的日期相关联,使用coalesce(字段,0)函数对值为空进行补0操作,就能查询出你期望的结果。
实现
在实际开发中只需要将2个日期2021-06-30和2022-05-31换成对应的开始日期参数和结束日期参数,那么这个统计结果就是符合期望的结果的了。