数据库报表:统计当前指标值比上月,比上季度,比年初,比去年同期增幅(同比)指标值,sql逻辑

数据表结构:RECORD_DT(日期)BANK_NO (机构号)ITEM_TP(统计类型)、CURR_CD(币种)、KPI(指标值)

  1. 首先筛选出上月底指标值,上季度指标值,去年底指标值,去年同期指标值
--dataofdate = '2022-06-08',每日跑上月底的数据 即 record_dt = '2022-05-31'

select
* 
from xxx.quota_orc
where (record_dt = trunc(to_date('#dataofdate#','yyyymmdd') -1 month,'mm') -1 day --上月底  --2022-04-30
      	or record_dt = trunc(date('#dataofdate#')-1 month,'q') -1 day	--上季度(最后一天) 2022-03-31
       	or record_dt = trunc(date('#dataofdate#')-1 month,'y') -1 day	--去年底 2021-12-31
        or record_dt = date(trunc(date('#dataofdate#'),'mm')-1 year) -1 day  --去年同期的数据 2021-05-31
      )
      and bank_no in ('xxxxxxx') and curr_cd = 'bwb'

数据样例

RECORD_DTBANK_NOITEM_TPCURR_CDKPI
2022-05-31xxxxxxx2022654BWB585984.00
2022-05-31xxxxxxx2022653BWB345984.00
2021-12-31xxxxxxx2022654BWB5342984.00
2021-05-31xxxxxxx2022654BWB583424.00
2022-04-30xxxxxxx2022654BWB4325984.00
2022-04-30xxxxxxx2022653BWB342984.00

最后统计成的结果,每行结构为:

RECORD_DT(日期)BANK_NO (机构号)ITEM_TP(统计类型)、CURR_CD(币种)、KPI(指标值)LST_MTH_KPI、LST_QTR_KPI、YR_BEGIN_KPI、T_KPI

综上所述,就是以**BANK_NO(机构号)、ITEM_TP(统计类型)、CURR_CD(币种)**为key(唯一),汇总不同时期的指标,到一行。

select
	t1.bank_no,t1.item_tp,t1.curr_cd,
	sum(case when record_dt = trunc(to_date('#dataofdate#','yyyymmdd') -1 month,'mm') -1 day then t1.kpi else 0 end) LST_MTH_KPI,
	sum(case when record_dt = trunc(date('#dataofdate#')-1 month,'q') -1 day then t1.kpi else 0 end) LST_QTR_KPI,
	sum(case when record_dt = trunc(date('#dataofdate#')-1 month,'y') -1 day then t1.kpi else 0 end) YR_BEGIN_KPI,
	sum(case when record_dt = date(trunc(date('#dataofdate#'),'mm')-1 year) -1 day then t1.kpi else 0 end) T_KPI
from xxx.quota_orc
where (record_dt = trunc(to_date('#dataofdate#','yyyymmdd') -1 month,'mm') -1 day --上月底  --2022-04-30
      	or record_dt = trunc(date('#dataofdate#')-1 month,'q') -1 day	--上季度(最后一天) 2022-03-31
       	or record_dt = trunc(date('#dataofdate#')-1 month,'y') -1 day	--去年底 2021-12-31
        or record_dt = date(trunc(date('#dataofdate#'),'mm')-1 year) -1 day  --去年同期的数据 2021-05-31
      )
      and bank_no in ('xxxxxxx') and curr_cd = 'bwb'
group by t1.bank_no,t1.item_tp,t1.curr_cd;
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值