例如表格数据:
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
oracle sql实现某数与表的一列数据进行比较相减后给下一行
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答
- danielinbiti 2015-07-23 09: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 )
解决 无用评论 打赏 举报
悬赏问题
- ¥15 stable diffusion
- ¥100 Jenkins自动化部署—悬赏100元
- ¥15 关于#python#的问题:求帮写python代码
- ¥20 MATLAB画图图形出现上下震荡的线条
- ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
- ¥15 perl MISA分析p3_in脚本出错
- ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
- ¥15 ubuntu虚拟机打包apk错误
- ¥199 rust编程架构设计的方案 有偿
- ¥15 回答4f系统的像差计算