例如表格数据:
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
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
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.Rfrom
(SELECT TEST_WF.*,ROWNUM R FROM TEST_WF) T
)