4

我一直在使用 TSQL 触发器,假设插入的表始终包含插入或更新的记录,而删除的表始终包含更新的记录(我忽略了删除)。

这是相关的 MSDN 文章:

http://msdn.microsoft.com/en-us/library/ms191300.aspx

但是,我遇到过插入和删除都是空的情况。这是我一直在使用的测试触发器。

CREATE TRIGGER [dbo].[InsertUpdateTest] ON [dbo].[Test] 
AFTER INSERT, UPDATE 
AS
    DECLARE @countInserted INT
    DECLARE @countDelete INT

    SET @countInsert = (SELECT COUNT(*) FROM INSERTED)
    SET @countDeleted = (SELECT COUNT(*) FROM DELETED)

    IF (@countInserted = 0 AND @countDelete = 0)
    BEGIN
        print 'Inserted and deleted are both empty'
    END

在什么条件下会发生这种情况?

4

1 回答 1

6

回答我自己的问题。当触发表上的更新语句没有更新任何行时,就会发生这种情况。触发器仍会触发,但插入和删除的表为空。例如:

UPDATE Test Set somefield=0 WHERE id='Values does not exist'
于 2012-08-03T07:42:52.580 回答