2 chyanwu68 chyanwu68 于 2015.07.23 16:56 提问

oracle sql实现某数与表的一列数据进行比较相减后给下一行
sql

例如表格数据:
ZD
1
2
3
4
实现:给任意一个数字(数字不大于表ZD列之和),当前以8说明
效果:
ZD ZD1
1 1
2 2
3 3
4 2
---规则:
第一行 8>1 所以ZD1为1,剩余7
第二行 7>2 所以ZD1为2,剩余5
第三行 5>3 所以ZD1为3,剩余2
第四行 2<4 所以ZD1为2,剩余0

2个回答

danielinbiti
danielinbiti   Ds   Rxr 2015.07.23 17:09
 CREATE TABLE TEST_WF(
  ZD INT
);
INSERT INTO TEST_WF VALUES(1);
INSERT INTO TEST_WF VALUES(2);
INSERT INTO TEST_WF VALUES(3);
INSERT INTO TEST_WF VALUES(4);
--结果语句
select zd,case when total>=s+zd then ZD else total-s end 结果
from(
SELECT T.*,NVL((SELECT SUM(ZD) FROM (
       SELECT ZD,ROWNUM R FROM TEST_WF T
) A WHERE A.R<T.R),0) s,8 total   --8在这里,可以自己改
from 
(SELECT TEST_WF.*,ROWNUM R FROM TEST_WF) T
)
danielinbiti
danielinbiti 回复维风: 如果有帮助,记得采纳一下哦
2 年多之前 回复
chyanwu68
chyanwu68 太厉害了 学习了
2 年多之前 回复
qq_25265293
qq_25265293   2015.07.23 23:27

SQL> create table tmp_1(zd number(3));
Table created

SQL> insert into tmp_1 select rownum from tab where rownum<5;
4 rows inserted

SQL> select zd,case when 8-sum(zd) over(order by rownum)>0 then zd else 8-sum(zd) over(order by rownum)+zd end as zd1 from tmp_1;
ZD ZD1


1 1
2 2
3 3
4 2

Csdn user default icon
上传中...
上传图片
插入图片