zoukankan      html  css  js  c++  java
  • 不用循环游标,一句update代码实现滚动计算

    发现一段经典SQL,不用循环游标,一句update代码实现滚动计算结存。为方便理解,结合实例测试之

    --1,源数据#t1,jcshl初值为每个sid的当前库存数量,要实现的效果:每个sid的后一结存数量为前一jcshl结存数量-chkshl出库数量
    SELECT * FROM #t1 ORDER BY sn

    sn plh sid chkshl jcshl
    1 S0002 20.0000 980.0000
    2 S0003 10.0000 1010.0000
    3 S0003 10.0000 1010.0000
    4 S0003 10.0000 1010.0000
    5 S0002 10.0000 980.0000
    6 S0002 1.0000 980.0000
    7 S0004 20.0000 720.0000
    8 S0005 10.0000 530.0000
    9 S0005 10.0000 530.0000
    10 S0005 10.0000 530.0000
    11 S0004 10.0000 720.0000
    12 S0004 1.0000 720.0000

    --2,按sid排序#t2,数据顺序决定分组及计算顺序
    SELECT * INTO #t2 FROM #t1 ORDER BY sid,sn

    sn plh sid chkshl jcshl
    1 S0002 20.0000 980.0000
    5 S0002 10.0000 980.0000
    6 S0002 1.0000 980.0000
    2 S0003 10.0000 1010.0000
    3 S0003 10.0000 1010.0000
    4 S0003 10.0000 1010.0000
    7 S0004 20.0000 720.0000
    11 S0004 10.0000 720.0000
    12 S0004 1.0000 720.0000
    8 S0005 10.0000 530.0000
    9 S0005 10.0000 530.0000
    10 S0005 10.0000 530.0000

    --3,滚动更新jcshl结存数量,同时填入新的plh排列号
    DECLARE @plh CHAR(11),@jcshl DECIMAL(18,4),@sid CHAR(11)
    
    UPDATE #t2 SET 
        @jcshl=jcshl=CASE WHEN sid=@sid THEN @jcshl-chkshl ELSE jcshl-chkshl END,
        @plh=plh=STR(ISNULL(@plh,0))+1,
        @sid=sid=sid
    
    SELECT * FROM #t2

    sn plh sid chkshl jcshl
    1 1 S0002 20.0000 960.0000
    5 2 S0002 10.0000 950.0000
    6 3 S0002 1.0000 949.0000
    2 4 S0003 10.0000 1000.0000
    3 5 S0003 10.0000 990.0000
    4 6 S0003 10.0000 980.0000
    7 7 S0004 20.0000 700.0000
    11 8 S0004 10.0000 690.0000
    12 9 S0004 1.0000 689.0000
    8 10 S0005 10.0000 520.0000
    9 11 S0005 10.0000 510.0000
    10 12 S0005 10.0000 500.0000

  • 相关阅读:
    ps一寸照片
    作用域链词法分析
    ajax加上随机数可以强制刷新网页
    ajaxStar,ajaxStop开始时候加载图片,加载完成之后去掉图片
    布尔变量 转换
    将2016-11-02转化成二零一六年十一月二日
    日期函数
    js数据类型
    编写页面分析
    小三角
  • 原文地址:https://www.cnblogs.com/hhlotus/p/12201674.html
Copyright © 2011-2022 走看看