【发布时间】:2012-02-14 16:37:54
【问题描述】:
这是一个 MS Access 应用程序,将表链接到 SQL Server。我需要在 SQL Server 上记录,因为我无法修改 MS Access 应用程序。
应用通过默认 SQL 用户名连接到 SQL Server。
【问题讨论】:
标签: sql-server sql-server-2005 ms-access ms-access-2003
这是一个 MS Access 应用程序,将表链接到 SQL Server。我需要在 SQL Server 上记录,因为我无法修改 MS Access 应用程序。
应用通过默认 SQL 用户名连接到 SQL Server。
【问题讨论】:
标签: sql-server sql-server-2005 ms-access ms-access-2003
为此,您需要一个触发器,以及一个存储结果的表。非常快速的原型:
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 几乎无法确定他们到底是谁)。
【讨论】:
BOGUS 的含义)。我不确定 Profiler 是如何显示实际用户名的 - 你确定它对所有用户都准确吗? Profiler 是从哪里运行的,与 Access 应用程序运行的同一台机器?
sys.dm_exec_connections.auth_scheme...