问题:我写了一个触发器,它应该在INVOICE
表之后将INSERT
表更新到LINE
表中,但它不会更新发票表。触发器触发但Update
语句块不会执行。
我在行表中执行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.'
END
答案 0 :(得分:4)
好吧,使用这样的声明:
select @linUnits = LINE_UNITS from inserted;
表示您假设触发器每行触发 - 它不。
每个语句触发一次SQL Server触发器 - 因此,如果您的语句在Line
表中插入多行,则触发器将触发一次以完成语句,但Inserted
伪表将包含多行数据。
因此,您需要重写触发器以将其考虑在内 - Inserted
表可以(并且将!)包含多行 - 并且您的触发器代码需要处理它。