postgresql查询每一天日期,并对未查到的日期结果补0

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换成对应的开始日期参数和结束日期参数,那么这个统计结果就是符合期望的结果的了。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值