Pgsql之查询一段时间内的所有日期

前几天干活儿的时候,项目中有这么个需求,需要用pgsql查询两个日期间的所有日期,包括年月日,下面贴代码:

 select date(t) as day
 from 
 generate_series('2020-10-27'::date,'2020-11-03', '1 days') as t;

下面是执行效果,跨年跨月的情况也是没问题的:

下面咱们说下PostgreSql中generate_series函数的用法:

用处:他可以按照不同的规则来生成填充数据

语法:

函数参数类型返回类型描述
generate_series(start,stop)int或bigintsetof int或setof bigint(与参数类型相同)生成一系列值,从start到stop ,步长为 1
generate_series(start,stop, step)int或bigintsetof int或setof bigint(与参数类型相同)功能生成一系列值,start到stop ,步长为step

 也可以用递归来做,其中recursive函数配合with查询来实现遍历,效率会更高一些:

with recursive t(n) as (
     select date('2020-10-27')
     union all 
     select n+1 from t where n < date('2020-11-03')
 )select n as day from t;

执行效果:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值