开发者社区 问答 正文

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

展开
收起
吴孟桥 2016-06-13 18:06:59 3290 分享 版权
1 条回答
写回答
取消 提交回答
  • 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
    )

    2019-07-17 19:36:41
    赞同 展开评论
问答分类:
SQL
问答地址: