rank() over(PARTITION by t.a, t.b, t.c, t.d order

select t1.a, t1.b, t1.c, t1.d, sum(decode(t1.rn, 1, t1.e, -t1.e)) ff
  from (select t.a,
               t.b,
               t.c,
               t.d,
               t.e,
               t.f,
               rank() over(PARTITION by t.a, t.b, t.c, t.d order by t.f desc) rn
          from ZZZ t) t1
 where t1.rn <= 2
 group by t1.a, t1.b, t1.c, t1.d; 
 --数据这样
1     1       1       1    10    2011
1     1       1       1    50    2012
1     1       1       1    100   2013
2     2       2       2    10    2011
2     2       2       2    50    2012 
2     2      2        2    100   2013
--不单单只有2哈 还有更多 
--出来的应该是这样的
1      1     1     1    50  
2      2      2    2   50
/**注意:使用rank()over(order by 排序字段 顺序)排序的时候,空值是最大的
(如果排序字段为null,可能造成在排序时将null字段排在最前面,影响排序的正确性。
所以建议将dense_rank()over(order by 列名 排序)改为dense_rank()over(order by 列名 排序 nulls last)
这样只要排序字段为null,就会放在最后,而不会影响排序结果).**/

转载于:https://my.oschina.net/u/1763152/blog/272349

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值