审计表的 SQL 触发器

标签 sql sql-server-2008 triggers sql-delete

我正在编写一个触发器来审核表中的更新和删除。我正在使用 SQL Server 2008

我的问题是,

有没有办法在不经过删除和插入表的选择阶段的情况下找出对记录采取的操作?

另一个问题是,如果记录被删除,我如何在审计表中记录执行删除的用户。 (注意:连接到数据库的用户是一个带有设置用户的通用连接字符串,我需要登录到 Web 应用程序或 Windows 应用程序的用户)

请帮忙?

最佳答案

对于第一部分,您可以设置单独的触发器或使用一个触发器来检查特殊表 INSERTEDDELETED 以区分更新和删除。

对于第二部分,在这种情况下没有办法绕过它,您将不得不通过您的 web/windows 应用程序以某种方式将该用户名获取到数据库中。不幸的是,您无法与触发器本身进行通信,并且使用通用连接字符串,DB 不知道它在与谁打交道。

我发现将“LastModifiedBy”列添加到您计划审核的表中会很有帮助,这样您就可以将该信息存储在原始表本身上。然后您的触发器只是将该信息复制到审计表中。这也很好,因为如果您只需要知道最后接触某事的人是谁,您根本不必查看审计表,只需检查该列即可。

关于审计表的 SQL 触发器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2999660/

相关文章:

SQL开关--为空白单元格填写 'n/a'

SQL:链接连接效率

database - 谁触发了我的扳机?

mysql - 如何在mysql的触发器中声明一个值?

MySQL查询以计算每个组内的百分比

php - 使用 php 查询选择所有订单

mysql - 转换sql中的日期格式?

sql - 比较有序 SQL 记录之间差异的快速方法

sql-server - 如何处理 "remapping can only be done for users that were mapped to Windows or SQL logins"

sql-server - 我应该使用 SQL Server 触发器来迁移数据库吗?