首页 > 数据库 > mysql教程 > 如何记录影响SQL Server中特定表的SQL语句?

如何记录影响SQL Server中特定表的SQL语句?

DDD
发布: 2025-01-03 01:00:39
原创
199 人浏览过

How Can I Log the SQL Statements Affecting a Specific Table in SQL Server?

在 SQL Server 中创建触发器来记录受影响的 SQL

在 SQL Server 2008 中,您可以创建触发器来捕获修改表的 SQL并记录下来以供审核。

触发器定义:

CREATE TRIGGER [dbo].[triggerAfterUpdate] 
   ON  [dbo].[TableWithMysteryUpdate] 
   AFTER UPDATE
AS 
BEGIN
    SET NOCOUNT ON;

    INSERT INTO [dbo].[LogTable] (
        ModifiedDate,
        ModifyingSQL
    )
    VALUES (
        GETDATE(),
        EVENTDATA()
    );
END
登录后复制

日志表定义:

CREATE TABLE [dbo].[LogTable] (
    [LogID] [INT] NOT NULL IDENTITY(1, 1),
    [ModifiedDate] [DATETIME] NOT NULL,
    [ModifyingSQL] [NVARCHAR](MAX) NOT NULL
);
登录后复制

使用示例:

创建后触发器,对 [dbo].[TableWithMysteryUpdate] 表的任何更新都将被记录[dbo].[LogTable].

附加说明:

  • EVENTDATA() 函数捕获触发事件的已执行 SQL 语句。
  • GETDATE()函数记录更新的日期和时间。
  • 您可以自定义日志表以包含其他信息,例如进行更新的用户或受影响的行。
  • 此方法提供了对修改特定表的 SQL 的可见性,而无需广泛的数据库知识。

以上是如何记录影响SQL Server中特定表的SQL语句?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板