⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 deliverydetail_update.sql

📁 用vb.net写的基于c/s结构的进销存程序设计源代码
💻 SQL
字号:
CREATE TRIGGER DeliveryDetail_Update
ON DeliveryDetail
FOR UPDATE 
AS
/* 如果修改记录数是0就结束触发程序 */ 
IF @@ROWCOUNT = 0 RETURN
/* 定义变量 
@DeliveryID : 出货单号
@DeliveryProperty : 出货单属性
@NewProductID : 新的商品编号
@OldProductID : 旧的商品编号
@NewQuantity : 新的数量
@OldQuantity : 旧的数量
*/
DECLARE @DeliveryID Char(10), @DeliveryProperty Char(1)
DECLARE @NewProductID Char(10), @OldProductID Char(10)
DECLARE @NewQuantity Decimal(12, 0), @OldQuantity Decimal(12, 0)
/* 找出修改的出货单号给DeliveryID, 修改后的商品编号给NewProductID, 修改后的数量给 NewQuantity */
SELECT @DeliveryID = DeliveryID, @NewProductID = ProductID, 
@NewQuantity = SalesQuantity
FROM inserted
/* 找出修改前的商品编号给NewProductID, 修改前的数量给 NewQuantity */
SELECT @OldProductID = ProductID, @OldQuantity = SalesQuantity
FROM deleted
/*找出这张出货单的出货属性*/
SELECT @DeliveryProperty = DeliveryProperty 
FROM DeliveryMaster 
WHERE DeliveryID = @DeliveryID
/*计算库存量*/
IF @DeliveryProperty = '1' 
  /*出货*/
  BEGIN
    /*新商品库存量减少*/
    UPDATE Product SET Quantity = Quantity - @NewQuantity                       
    WHERE ProductID = @NewProductID
    /*旧商品库存量加回*/
    UPDATE Product SET Quantity = Quantity + @OldQuantity                       
    WHERE ProductID = @OldProductID
  END
ELSE	
  /*出货退回:*/
  BEGIN
    /*新商品库存量增加*/
    UPDATE Product SET Quantity = Quantity + @NewQuantity                       
    WHERE ProductID = @NewProductID
    /*旧商品库存量减掉*/
    UPDATE Product SET Quantity = Quantity - @OldQuantity                       
    WHERE ProductID = @OldProductID
  END


⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -