程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Oracle sum group by column range with different起始点大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决Oracle sum group by column range with different起始点?

开发过程中遇到Oracle sum group by column range with different起始点的问题如何解决?下面主要结合日常开发的经验,给出你关于Oracle sum group by column range with different起始点的解决方法建议,希望对你解决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| 

我如何才能高效地做到这一点。

解决方法

你似乎想要:

SELEct user_x,sdate,sum(amount)
from t
where ndate >= sdate
group by user_x,sdate;

大佬总结

以上是大佬教程为你收集整理的Oracle sum group by column range with different起始点全部内容,希望文章能够帮你解决Oracle sum group by column range with different起始点所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。