SQL Server比较同一个表的两行的值,并且不匹配列名

时间:2015-09-21 08:17:48

标签: sql sql-server tsql triggers

我需要比较同一个表的两行(INSERTED& DELETED)并比较值。然后我需要得到不匹配的列。在触发器内。

这是我到目前为止所尝试过的,但我不知道如何比较这两行并获取包含不同值的列名。

SELECT * 
FROM inserted i
INNER JOIN deleted d ON d.PurchasingDocItemNo = i.PurchasingDocItemNo 
                     AND d.PurchasingDocNo = i.PurchasingDocNo
                     AND d.ReferenceDocumentNo = i.ReferenceDocumentNo
                     AND d.ProductNo = i.ProductNo

1 个答案:

答案 0 :(得分:1)

将您的选择更改为:

SELECT
-- For each column you're checking.  Also account for ISNull if you need to
CASE WHEN I.Col1 = D.Col1 THEN 0 ELSE 1 END AS Col1Changed.......
FROM INSERTED I
INNER JOIN DELETED D on (I.<PK> = D.<PK>)
相关问题