大佬教程收集整理的这篇文章主要介绍了Oracle sum group by column range with different起始点,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我有以下示例数据。我想找到每个相应 sum(amount)
的总 user_x
,但从分配给每个用户的 sdate
开始。相应用户中的 sdate
不会改变
NDATE |SDATE |user_X|amouNT|
--------|--------|------|------|
20210403|20210501|A | 1|
20210402|20210501|A | 2|
20210503|20210501|A | 3|
20210506|20210501|A | 4|
20210403|20210401|B | 5|
20210503|20210401|B | 2|
20210303|20210401|B | 3|
20210403|20210511|C | 3|
20210403|20210511|C | 4|
20210403|20210511|C | 5|
我在下面尝试返回所有结果,我只想要每个 user_x
一行结果
SELECT
user_x,sdate,sum(cASE WHEN sdate < ndate THEN amount ELSE 0 END) OVER (PARTITION BY user_x ORDER BY ndatE) sumation
FROM (
SELECT ndate,user_x,amount FROM (
SELECT 20210403 ndate,20210501 sdate,'A' user_x,1 amount from dual union all
SELECT 20210402 ndate,2 amount from dual union all
SELECT 20210503 ndate,3 amount from dual union all
SELECT 20210506 ndate,4 amount from dual union all
SELECT 20210403 ndate,20210401 sdate,'B' user_x,5 amount from dual union all
SELECT 20210503 ndate,2 amount from dual union all
SELECT 20210303 ndate,3 amount from dual union all
SELECT 20210403 ndate,20210511 sdate,'C' user_x,4 amount from dual union all
SELECT 20210403 ndate,5 amount from dual
) )
这就是我想要的
user_X|SDATE |SUMATION|
------|--------|--------|
A |20210501| 7|
B |20210401| 7|
我如何才能高效地做到这一点。
以上是大佬教程为你收集整理的Oracle sum group by column range with different起始点全部内容,希望文章能够帮你解决Oracle sum group by column range with different起始点所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。