[postgresql]postgresqlg使用generate_series() 函数补全统计

目录

1.需求

2.generate_series函数

3.实例

3.1 间隔1天

3.2  间隔1小时

3.3 间隔1分钟


1.需求

比如高速公路的某个门架的过车明细数据如下:

 需求:
       需要按天统计通过该门架的过车总数量,没有过车的时候统计为0,即7月13日没有记录也要在报表中表示为0

with t1 as 
(
select generate_series('2022-07-10'::date,'2022-07-17'::date,'1 day') as day
),
t2 (
select 
    pass_id,
    capture_time,
    to_char(capture_time,'yyyy-mm-dd')::date as capture_date,
    grantry_code,
 from sdi_op_toll_station_pass_detail_t 
)
select day,grantry_code,count(pass_id) as cnt
from t1 left join t2
on t1.day=t2.capture_date
group by day,grantry_code;

2.generate_series函数

函数参数类型返回类型描述
generate_series(start, stop)int 或 bigintint 或 bigint(与参数类型相同)生成一个数值序列,从start 到 stop,步进为一
generate_series(start, stop, step)int 或 bigint int 或 bigint(与参数类型相同)生成一个数值序列,从start 到 stop,步进为step
generate_series(start, stop, step_interval)timestamp or timestamp with time zonetimestamp 或 timestamp with time zone(与参数类型相同)生成一个数值序列,从start 到 stop,步进为step

3.实例

3.1 间隔1天

select generate_series('2022-07-10'::date,'2022-07-17'::date,'1 day')

3.2  间隔1小时

select generate_series('2022-07-10'::date,'2022-07-17'::date,'1 hour')

3.3 间隔1分钟

select generate_series('2022-07-10'::date,'2022-07-17'::date,'1 min')

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值