在SQL Server中,可以通过使用触发器来捕获两列的更改。下面是一个包含代码示例的解决方法:
首先,创建一个表来存储更改的历史记录。该表将记录更改前后的值以及更改发生的时间。例如,可以创建一个名为ChangeHistory
的表,包含以下列:
CREATE TABLE ChangeHistory (
ID INT IDENTITY(1,1) PRIMARY KEY,
TableName VARCHAR(100),
ColumnName VARCHAR(100),
OldValue NVARCHAR(MAX),
NewValue NVARCHAR(MAX),
ChangeDate DATETIME
)
接下来,创建一个触发器在更改目标表中的两列发生更改时被触发。例如,如果目标表名为YourTable
,两列分别为Column1
和Column2
,则可以创建以下触发器:
CREATE TRIGGER CaptureChanges
ON YourTable
AFTER UPDATE
AS
BEGIN
IF UPDATE(Column1) OR UPDATE(Column2)
BEGIN
INSERT INTO ChangeHistory (TableName, ColumnName, OldValue, NewValue, ChangeDate)
SELECT
'YourTable',
CASE
WHEN UPDATE(Column1) THEN 'Column1'
WHEN UPDATE(Column2) THEN 'Column2'
END,
d.Column1,
i.Column1,
GETDATE()
FROM deleted d
INNER JOIN inserted i ON d.PrimaryKeyColumn = i.PrimaryKeyColumn -- 用于链接原始值和新值的主键列
WHERE
(UPDATE(Column1) AND d.Column1 <> i.Column1) OR
(UPDATE(Column2) AND d.Column2 <> i.Column2)
END
END
触发器将在YourTable
表的Column1
或Column2
被更新时被触发。它将在ChangeHistory
表中插入一条记录,记录更改前后的值以及更改发生的时间。
请注意,上述示例中的触发器假设目标表具有一个主键列,用于将原始值和新值进行匹配。如果目标表没有主键列,您可以根据具体情况将触发器进行修改,以使用其他唯一标识列或组合列来链接原始值和新值。
下一篇:捕获两种不同情况的正则表达式