如何记录哪些用户删除了 MS Access 中的记录?

Posted

技术标签:

【中文标题】如何记录哪些用户删除了 MS Access 中的记录?【英文标题】:How do I log what user deleted a record in MS Access? 【发布时间】:2012-02-14 16:37:54 【问题描述】:

这是一个 MS Access 应用程序,将表链接到 SQL Server。我需要在 SQL Server 上记录,因为我无法修改 MS Access 应用程序。

应用通过默认 SQL 用户名连接到 SQL Server。

【问题讨论】:

【参考方案1】:

为此,您需要一个触发器,以及一个存储结果的表。非常快速的原型:

CREATE TRIGGER dbo.trigger_name
ON dbo.table_name
FOR DELETE
AS
    INSERT INTO dbo.LogTable(RowID, UserName)
        SELECT PK_Column, SUSER_SNAME()
        FROM deleted;
GO

请注意,除非每个 Access 用户都以自己的身份向 SQL Server 进行身份验证,否则您可能需要使用主机名或其他一些属性来识别他们(如果他们都以同一个 SQL 用户身份连接,则 SQL Server 几乎无法确定他们到底是谁)。

【讨论】:

由于某种原因,当我使用 HOSTNAME() 时,它会为异地用户的多个用户返回相同的 HOSTNAME()。我觉得是网络问题。 SUSERNAME() 返回 BOGUS。我无法修改 Access 应用程序,因此我无法让它们各自进行身份验证。 是的,SQL Server 无法访问远程计算机以查看主机名,它只能看到将该请求传递给 SQL Server 的任何主机名。如果他们使用 SQL 身份验证,您将很难获得 Windows 用户名(我假设这就是 BOGUS 的含义)。我不确定 Profiler 是如何显示实际用户名的 - 你确定它对所有用户都准确吗? Profiler 是从哪里运行的,与 Access 应用程序运行的同一台机器? Profiler 在我的机器上运行,而 SQL Server 在服务器上运行,而 Access 应用程序从不同的网络共享运行。 有趣。 SUSER_SNAME() 适用于某些用户而不适用于其他用户。对于某些显示 dom\user 其他显示 BOGUS。 你确定他们都在使用 SQL 身份验证吗?你应该可以查看sys.dm_exec_connections.auth_scheme...

以上是关于如何记录哪些用户删除了 MS Access 中的记录?的主要内容,如果未能解决你的问题,请参考以下文章

MS Access 中的条件选择语句

如何使 ms access 数据库可供多个用户使用?

通过连接到 MS Access 的 Java Eclipse 无法使用删除查询删除记录

反映在 MS ACCESS 2013 中进行记录更新的 Windows 用户 ID 和时间

MS Access:从子表单中删除记录时捕获值

如何根据每条记录的连续表单中 ms-access 中的其他值填充文本框上的值