同様の要件がありますが、追跡する監査が必要なすべてのテーブルに次の 4 つの列を追加することで対応しました。
[Create_User] [nvarchar](100) NULL,
[Create_Date] [datetimeoffset](7) NULL,
[Modify_User] [nvarchar](100) NULL,
[Modify_Date] [datetimeoffset](7) NULL,
INSERT トリガーは次のようになります。
CREATE TRIGGER [SomeSchema].[Some_Table_Insert_Create] ON [SomeSchema].[Some_Table] FOR INSERT AS
SET NOCOUNT ON
IF EXISTS(SELECT * FROM INSERTED WHERE Create_User IS NOT NULL)
BEGIN
UPDATE [SomeSchema].[Some_Table] SET
Create_Date = SYSDATETIMEOFFSET()
FROM
[SomeSchema].[Some_Table]
INNER JOIN
INSERTED
ON
[SomeSchema].[Some_Table].Some_Table_Id = INSERTED.Some_Table_Id
END
ELSE
BEGIN
UPDATE [SomeSchema].[Some_Table] SET
Create_User = SUSER_SNAME(),
Create_Date = SYSDATETIMEOFFSET()
FROM
[SomeSchema].[Some_Table]
INNER JOIN
INSERTED
ON
[SomeSchema].[Some_Table].Some_Table_Id = INSERTED.Some_Table_Id
END
そして、UPDATE トリガーは次のようになります。
CREATE TRIGGER [SomeSchema].[Some_Table_Update_Modify] ON [SomeSchema].[Some_Table] FOR UPDATE AS
SET NOCOUNT ON
IF NOT UPDATE (Create_User) AND NOT UPDATE (Create_Date)
BEGIN
IF EXISTS(SELECT * FROM INSERTED WHERE Modify_User IS NOT NULL)
BEGIN
UPDATE [SomeSchema].[Some_Table] SET
Modify_Date = SYSDATETIMEOFFSET()
FROM
[SomeSchema].[Some_Table]
INNER JOIN
INSERTED
ON
[SomeSchema].[Some_Table].Some_Table_Id = INSERTED.Some_Table_Id
END
ELSE
BEGIN
UPDATE [SomeSchema].[Some_Table] SET
Modify_User = SUSER_SNAME(),
Modify_Date = SYSDATETIMEOFFSET()
FROM
[SomeSchema].[Some_Table]
INNER JOIN
INSERTED
ON
[SomeSchema].[Some_Table].Some_Table_Id = INSERTED.Some_Table_Id
END
END
SUSER_SNAME() 関数は、アプリでの偽装と DB への接続に Windows 認証を使用しているため、使用に便利です。これはあなたのケースではうまくいかないかもしれません。