以下的文章主要向大家讲述的是SQL Server 2005DDL触发器监控数据库的相关变化,添加,删除或是修改数据库的相关对象,一旦误操作,可能会导致 *** 烦,需要一个数据库治理员或开发人员对相关可能受影响的实体进行代码的重写。
为了在数据库结构发生变动而出现问题时,能够跟踪问题,定位问题的根源,我们可以利用SQL Server 2005DDL触发器来记录类似“用户建立表”这种变化的操作,这样可以大大减轻跟踪和定位数据库模式的变化的繁琐程度。
(1)DDL触发器介绍
DDL 触发器是一种非凡的触发器,它在响应数据定义语言 (DDL) 语句时触发。它们可以用于在数据库中执行治理任务,例如,审核以及规范数据库操作。
(2)使用 DDL 触发器,可以达到以下几种目的:
A:要防止对数据库架构进行某些更改。
B:希望数据库中发生某种情况以响应数据库架构中的更改。
C:要记录数据库架构中的更改或事件。
与标准的DML触发器一样,DDL 触发器在响应事件时执行存储过程。 但与标准的DML触发器不同的是,它们并不在响应对表或视图的 UPDATE、INSERT 或 DELETE 语句时执行存储过程。 它们主要在响应数据定义语言 (DDL) 语句执行存储过程。 这些语句包括 CREATE、ALTER、DROP、GRANT、DENY、REVOKE 和 UPDATE stATISTICS 等语句。 执行 DDL 式操作的系统存储过程也可以激发 DDL 触发器。
(3)如何使用DDL触发器
之一步,需要建立一个表,用来记录数据库范围内所有DDL操作。
下面的代码在PB2K数据库中创建一个表,用于保存所有DDL操作记录:
USE AdventureWork GO CREATE TABLE Auditlog (ID INT PRIMARY KEY IDENTITY(1,1), Command NVARCHAR(1000), PostTime NVARCHAR(24), HostName NVARCHAR(100), LoginName NVARCHAR(100) ) GO
第二步,用于保存DDL事件的表在创建好之后,还需要建立一个SQL Server 2005DDL触发器,监控PB2K数据库中DDL_DATABASE_LEVEL_EVENTS级别的所有事件:
CREATE TRIGGER Audit ON DATABASE FOR DDL_DATABASE_LEVEL_EVENTS AS DECLARE @data XML DECLARE @cmd NVARCHAR(1000) DECLARE @posttime NVARCHAR(24) DECLARE @spid NVARCHAR(6) DECLARE @loginname NVARCHAR(100) DECLARE @hostname NVARCHAR(100) SET @data=EVENTDATA() SET @cmd=@data.value('(/EVENT_INSTANCE/TSQLCommand/CommandText)[1]','NVARCHAR(1000)') SET@cmd=LTRIM(RTRIM(REPLACE(@cmd,'',''))) SET@posttime=@data.value('(/EVENT_INSTANCE/PostTime)[1]','NVARCHAR(24)') SET@spid=@data.value('(/EVENT_INSTANCE/SPID)[1]','nvarchar(6)') SET@loginname=@data.value('(/EVENT_INSTANCE/LoginName)[1]', 'NVARCHAR(100)') SET@hostname=HOST_NAME() INSERT INTO dbo.AuditLog(Command,PostTime,HostName,LoginName) VALUES(@cmd,@posttime,@hostname,@loginname) GO
使用 EVENTDATA 函数,可以捕捉有关激发 DDL 触发器的事件的信息,并将其保存到我们的AuditLog日志表中。EVENTDATA 函数的是返回 xml 值,采用以下的命令进行解析:
SET @cmd = LTRIM(RTRIM(REPLACE(@cmd,'','')))
需要LTRIM和RTRIM是所有的左边的前导空格和右边的尾随空格,而REPLACE函数是用来消除使用S *** S脚本向导时所带来的回车。
第三步,一旦建立了表和触发器,我们就可以用以下的操作,来测试看看SQL Server 2005DDL触发器是否正常运行:
UPDATE STATISTICS Production.Product GO CREATE TABLE dbo.Test(col INT) GO DROP TABLE dbo.Test GO --View log table SELECT * FROM dbo.AuditLog GO
执行后,查询结果如下所示:

图1: AuditLog日志表查询结果
(4)小结
通过创建一个日志表来保存所有DDL操作以及创建数据库级别的SQL Server 2005DDL触发器,我们能够成功地捕捉我们的数据库中所有DDL级的变化,为DBA跟踪和监视任何改变提供了更强大的功能。
很多使用Windows 7系统的朋友都想小编反应,假如暂停使用电脑,鼠标会出现停顿现象,这是怎么回事呢 该怎么解决呢 下面就和小编一起去看下Windows 7 usb鼠标停顿的解决方法吧。 由于Windows 7系统中有一项USB选择性暂停造成的。这项设置主要为了节电,当他检测到用户没有对系统进行...
在Windows 7系统的默认设置中,当Windows 7系统处于休眠状态时,会同时断网的。如此一来,无论你正在使用迅雷还是快车等下载工具,同样可以在休眠状态下继续完成下载,最大限度做到从身边的小事开始支持环保。下面我们就详细介绍操作步骤,帮助Windows 7系统用户实现这一节能目标。 首先需要...
对于Windows 7系统来说,其默认安装的许多工具是我们很少使用或从来不用的,比如系统自带的扫雷、纸牌游戏等。删除此类长期不用的系统组件,不但可以让系统更清爽,更重要的是还可以提高系统的运行速度,特别是对于硬件配置相对较低的上网本来说,尤其如此。接下来,笔者就给大家介绍一下如何删除Windows...
有些使用本本的朋友可能会发现,右下角通知栏区域会无法显示电源按钮,导致在插上电源或者是使用电池的时候都无法进行区分。造成这种情况大部分都是因为使用了第三方修改过的系统版本或者对于系统优化过度,所以今天就来解决这个问题。 第一步:在开始菜单的搜索窗口输入“gpedit.msc”,进入组策略编辑器,依...
假如碰到电脑里的文件夹和文件全都不显示名字了(如下图),是不是电脑中毒了呢 请教下笔者有没好的解决方法!下面是笔者给出的答案,希望能够帮助到大家! 首先打开你用来装图片的文件夹(缩略图下面的文字不显示的文件夹),然后但击工具栏上的“查看”选择“平铺”, 下面就是关键:要按住SHIFT键不...
最近一些Windows 7用户反馈说,自己在截屏的时候出现黑屏,导致自己截的图黑呼呼一片。这个问题该怎么解决?今天小编就为大家提供一个解决的方法。 步骤 1 在windows xp时代,很多用户都曾被视频截图后的“全黑图片”困扰。对此,在解决本地播放时出现的截图变黑问题,一般有两个方法可以用来解...