0

问题:我写了一个触发器,它应该在进入INVOICE表之后更新表,但它不会更新发票表。触发器触发,但语句块不会执行。INSERTLINEUpdate

我在执行INSERT到行表时进行了调试,发现一旦到达UPDATE语句,它就会跳过它并且不运行该代码。几天来,我一直试图弄清楚这一点。

这是我的触发代码

ALTER TRIGGER [dbo].[trgInvoiceInsert] ON [dbo].[LINE]
AFTER INSERT
AS
  declare @linUnits numeric(9,2);
  declare @linPrice numeric(9,2);
  declare @invNum   int;

  select @linUnits = LINE_UNITS from inserted;
  select @linPrice = LINE_PRICE from inserted;
  select @invNum = INV_NUMBER from inserted;
BEGIN
 UPDATE i --From here it jumps to the start of the next Update
    SET INV_SUBTOTAL = INV_SUBTOTAL + (@linUnits * @linPrice)
 FROM dbo.INVOICE as i
 WHERE i.INV_NUMBER = @invNum 

 UPDATE i
    SET INV_TOTAL = INV_SUBTOTAL + INV_TAX  
 FROM dbo.INVOICE as i
 WHERE i.INV_NUMBER = @invNum 


 PRINT 'Trigger fired Successfully.'

结尾

4

1 回答 1

5

好吧,使用这样的语句:

select @linUnits = LINE_UNITS from inserted;

表示您假设触发器每行触发- 它没有

SQL Server 触发器每条语句触发一次- 因此,如果您的语句向表中插入多行Line,您的触发器将为完整的语句触发一次,但Inserted伪表将包含多行数据。

因此,您需要重写触发器以考虑到这一点 -Inserted表可以(并且将!)包含多行 - 并且您的触发器代码需要处理这一点。

于 2013-04-09T20:24:57.820 回答