postgresql 序列和递归

一、需求:

     查询某个时间段的所有日期,通过序列和递归测试效率

    1、序列

         postgresql中的generate_series函数可以按不同的规则产生一系列的填充数据

         具体可以参考链接:

         https://www.cnblogs.com/mchina/archive/2013/04/03/2997722.html

select date(t) as day
from generate_series('2019-04-27'::date,'2020-05-09', '1 days') as t

 

    2、递归查询

with recursive t(n) as (
    select date('2020-04-27')
    union all 
    select n+1 from t where n < date('2020-05-09')
)select n as day from t;

   查询结果:

       

总结:

当数据量小的时候进行测试,序列语句执行了0.004s;递归语句执行了0.007s

当数据量大的时候进行测试,序列语句执行力0.006s;递归语句执行了0.004s

二、举一反三

月份每次加一个月或者加三个月时:

with recursive t(val) as (
    select '2019-04-27'::timestamp
    union all 
    select val + interval '3 month' from t where val < CURRENT_DATE
)select to_char(val,'yyyy-mm-dd') as month from t

时间每次增加三个小时:

select generate_series(to_date('20130403','yyyymmdd'), to_date('20130409','yyyymmdd'), '3 hours')

三、参考一个递归例子

http://blog.itpub.net/24362799/viewspace-1145920/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值