分段累计

【问题】

有这样一组数据 a,b 两字段
a      b
10     3
21     4
33     6
46     7
52     10
现在想得到这样的结果
a<10   sum(b)
a<20   sum(b)
a<30  sum(b)
a<40  sum(b)
a<50  sum(b)

即:
10    0
20    3
30    7
40    13
50    20
这样的需求 SQL 应该怎么写啊?数据 a 的值有很大有 1000 个段啊。

【回答】

Oracle 中可以建立辅助区间表结合分析函数实现,实现方式过于复杂,使用 SPL 实现就比较简单,脚本如下:

A
1$SELECT A,B FROM TB1ORDER BYA
2=A1.groups((A)\10+1;sum(B)).new(#1*10:C,sum(#2[:0]):D)

A1:查找数据

A2:分组统计,生成当前区间,并汇总小于当前区间的值,生成新序表。

运行结果:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值