更改过程不会更新departmentID

时间:2013-09-11 20:03:32

标签: sql sql-server sql-server-2008

我修改了以下程序,按部门显示项目库存。但是,这似乎并没有更新部门。我不确定该程序有什么问题。有帮助吗?

ALTER PROCEDURE [dbo].[GetWHInventoryValue]
AS
  BEGIN
      -- SET NOCOUNT ON added to prevent extra result sets from
      -- interfering with SELECT statements.
      SET NOCOUNT ON;

      DECLARE @loccode CHAR(3)
      DECLARE @locationID CHAR(10)

      DELETE FROM DailySummaries
      WHERE  Item = 119;

      DECLARE activeLocations CURSOR FOR
        SELECT warehouseid,
               whcode
        FROM   warehouse
        WHERE  inactive != 'T';

      OPEN activeLocations

      FETCH next FROM activeLocations INTO @locationID, @loccode

      WHILE( @@FETCH_STATUS = 0 )
        BEGIN
            INSERT INTO DailySummaries
                        (Item,
                         Location,
                         Amount,
                         DepartmentID,
                         [Date])
            VALUES     (119,
                        @loccode,
                        0,
                        0,
                        GETDATE());

            DECLARE @whTotal NUMERIC(13, 2)
            DECLARE @itemID CHAR(10)
            DECLARE @itemCost NUMERIC(11, 2)
            DECLARE @departmentID CHAR(12)

            DECLARE whItems CURSOR FOR
              SELECT mst.masterid,
                     mst.replacementcost,
                     mv.inventorydepartmentid
              FROM   masterwh AS wh,
                     [master] AS mst,
                     masterview mv
              WHERE  mst.masterid = wh.masterid
                     AND wh.warehouseid = @locationid
                     AND mv.masterid = mst.masterid
                     AND mv.warehouseid = wh.warehouseid

            OPEN whItems;

            FETCH next FROM whItems INTO @itemID, @itemCost, @departmentID

            WHILE( @@FETCH_STATUS = 0 )
              BEGIN
                  DECLARE @itemQty NUMERIC(11, 2)

                  DECLARE itemQty CURSOR FOR
                    SELECT SUM(mw.qty)
                    FROM   masterwhqty mw,
                           masterview mv
                    WHERE  mw.warehouseid = @locationid
                           AND mw.masterid = @itemID
                           AND mw.qty > 0
                           AND mv.masterid = mw.masterid
                           AND mv.warehouseid = mw.warehouseid
                           AND mv.inventorydepartmentid = @departmentID;

                  OPEN itemQty;

                  FETCH next FROM itemQty INTO @itemQty;

                  UPDATE DailySummaries
                  SET    amount = amount + ( isnull(@itemQty, 0) * @itemCost ),
                         DepartmentID = @departmentID
                  WHERE  Location = @loccode
                         AND Item = 119
                         AND DepartmentID = @departmentID;

                  DEALLOCATE itemQty;

                  FETCH next FROM whItems INTO @itemID, @itemCost, @departmentID
              END

            DEALLOCATE whItems;

            FETCH next FROM activeLocations INTO @locationID, @loccode
        END

      DEALLOCATE activeLocations;
  END 

1 个答案:

答案 0 :(得分:3)

这是您的更新代码:

UPDATE DailySummaries SET amount = amount + (isnull(@itemQty,0) * @itemCost), DepartmentID=@departmentID WHERE Location = @loccode AND Item = 119  and DepartmentID=@departmentID;

这里我只提取了相关部分:

SET DepartmentID = @departmentID WHERE DepartmentID = @departmentID;

您会注意到使用此类代码进行更新吗?