好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

SQLServer实现用触发器捕获DML操作的会话信息【实例】

需求背景

上周遇到了这样一个需求,维护人员发现一个表的数据经常被修改,由于历史原因;文档缺少;以及维护人员的经常变更,导致他们对系统也业务也不完全熟悉,他们也不完全清楚哪些系统和应用程序会对这个表的数据进行操作。现在他们想找出有哪些服务器,哪些应用程序会对这个表进行INSERT、UPDATE操作。那么问题来了,怎么去解决这个问题呢?

解决方案

由于数据库版本是标准版,我们选择了使用触发器来捕获进行DML操作的会话的相关信息,例如,Host_Name、Program_Name等 ,选择触发器是因为简单直接。我们先创建一个表名为TEST的表,假设我们想监控有哪些应用服务器,以及那些应用程序会对表TEST进行INSERT、UPDATE操作。

USE [AdventureWorks2014]

GO

 

IF NOT EXISTS (SELECT 1 FROM sys.sysobjects WHERE id=object_id(N'[dbo].[TEST]') AND OBJECTPROPERTY(id, N'IsTable')=1 )

BEGIN

CREATE TABLE [dbo].[TEST](

  [OBJECT_ID] [INT] NOT NULL,

  [NAME] [VARCHAR](8) NULL,

  CONSTRAINT PK_TEST  PRIMARY KEY (OBJECT_ID)

) 

END

GO

 

INSERT INTO dbo.TEST

SELECT 1, 'kerry' UNION ALL

SELECT 2, 'jimmy' 

查看更多关于SQLServer实现用触发器捕获DML操作的会话信息【实例】的详细内容...

  阅读:59次