SQL Server 2005中使用DDL触发器监控数据库变化

2016-02-19 19:34 4 1 收藏

下面图老师小编要向大家介绍下SQL Server 2005中使用DDL触发器监控数据库变化,看起来复杂实则是简单的,掌握好技巧就OK,喜欢就赶紧收藏起来吧!

【 tulaoshi.com - 编程语言 】

  添加,删除或修改数据库的对象,一旦误操作,可能会导致大麻烦,需要一个数据库管理员或开发人员对相关可能受影响的实体进行代码的重写。

  为了在数据库结构发生变动而出现问题时,能够跟踪问题,定位问题的根源,我们可以利用DDL触发器来记录类似“用户建立表”这种变化的操作,这样可以大大减轻跟踪和定位数据库模式的变化的繁琐程度。

  1、DDL触发器介绍

  DDL 触发器是一种特殊的触发器,它在响应数据定义语言 (DDL) 语句时触发。它们可以用于在数据库中执行管理任务,例如,审核以及规范数据库操作。

  使用 DDL 触发器,可以达到以下几种目的:

  要防止对数据库架构进行某些更改。

  希望数据库中发生某种情况以响应数据库架构中的更改。

  要记录数据库架构中的更改或事件。

  与标准的DML触发器一样,DDL 触发器在响应事件时执行存储过程。 但与标准的DML触发器不同的是,它们并不在响应对表或视图的 UPDATE、INSERT 或 DELETE 语句时执行存储过程。 它们主要在响应数据定义语言 (DDL) 语句执行存储过程。 这些语句包括 CREATE、ALTER、DROP、GRANT、DENY、REVOKE 和 UPDATE STATISTICS 等语句。 执行 DDL 式操作的系统存储过程也可以激发 DDL 触发器。

  2、如何使用DDL触发器

  第一步,需要建立一个表,用来记录数据库范围内所有DDL操作。

  下面的代码在AdventureWorks范例数据库中创建一个表,用于保存所有DDL操作记录:

  USEAdventureWorks
  GO
  CREATETABLEAuditLog
  (IDINTPRIMARYKEYIDENTITY(1,1),
  CommandNVARCHAR(1000),
  PostTimeNVARCHAR(24),
  HostNameNVARCHAR(100),
  LoginNameNVARCHAR(100)
  )
  GO

  用于保存DDL事件的表在创建好之后,还需要建立一个DDL触发器,监控AdventureWorks数据库中DDL_DATABASE_LEVEL_EVENTS级别的所有事件:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  CREATETRIGGERAuditONDATABASE
  FORDDL_DATABASE_LEVEL_EVENTS
  AS
  DECLARE@dataXML
  DECLARE@cmdNVARCHAR(1000)
  DECLARE@posttimeNVARCHAR(24)
  DECLARE@spidNVARCHAR(6)
  DECLARE@loginnameNVARCHAR(100)
  DECLARE@hostnameNVARCHAR(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()
  INSERTINTOdbo.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函数是用来消除使用SSMS脚本向导时所带来的回车。

  一旦建立了表和触发器,您就可以用以下的操作,来测试看看DDL触发器是否正常运行:

  UPDATESTATISTICSProduction.Product
  GO
  CREATETABLEdbo.Test(colINT)
  GO
  DROPTABLEdbo.Test
  GO
  --Viewlogtable
  SELECT*
  FROMdbo.AuditLog
  GO

  执行后,查询结果如下所示:

图1: AuditLog日志表查询结果

  3、小结

  通过创建一个日志表来保存所有DDL操作以及创建数据库级别的DDL触发器,我们能够成功地捕获我们的数据库中所有DDL级的变化,为DBA跟踪和监视任何改变提供了更强大的功能。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

来源:http://www.tulaoshi.com/n/20160219/1621343.html

延伸阅读
标签: SQLServer
SQL Server并非微软经常更新的产品,所以当微软要发布一个更新,就值得我们去关注。因此,在从以前的SQL Server 2000或者SQL Server 7升级到最近发布的SQL Server 2005之前,你有必要了解有关这方面的一些更新内容。 一点提醒:SQL Server 2005 从最基本的数据库发展到真正意义上的企业级产品,能够支持最大的数据仓库。虽然老式的SQL Serve...
触发器的概念:“在数据库中为响应一个特殊表格中的某些事件而自动执行的程序代码。”(Wikipedia)说得简单一些,它是在一个特殊的数据库事件,如INSERT或DELETE发生时,自动激活的一段代码。触发器可方便地用于日志记录、对单个表格到其他链接式表格进行自动的“层叠式”更改、或保证对表格关系进行自动更新。当一个新整数值增加到数据库域中时...
标签: MySQL mysql数据库
在SQL中,名词触发器指“在数据库中为响应一个特殊表格中的某些事件而自动执行的程序代码。”(Wikipedia)说得简单一些,它是在一个特殊的数据库事件,如INSERT或DELETE发生时,自动激活的一段代码。触发器可方便地用于日志记录、对单个表格到其他链接式表格进行自动的“层叠式”更改、或保证对表格关系进行自动更新。当一个新整数值增加到数据...
标签: MySQL mysql数据库
在SQL中,名词触发器指“在数据库中为响应一个特殊表格中的某些事件而自动执行的程序代码。”(Wikipedia)说得简单一些,它是在一个特殊的数据库事件,如INSERT或DELETE发生时,自动激活的一段代码。触发器可方便地用于日志记录、对单个表格到其他链接式表格进行自动的“层叠式”更改、或保证对表格关系进行自动更新。当一个新整数值增加到数据库...
曾经以为SQL SERVER的触发器只能触发单行,也就是说如果一个delete触发器,如果同时删除多行时,只会对第一条记录触发,后来发现了不是人家SQL SERVER不支持,而是偶脑子笨没发现。 其实inserted和deleted两张内部表存放了所有要插入或要删除的记录,可以用cursor逐次访问里面的每条记录,下面是一个示例,该触发器将要删除的记录转移...

经验教程

656

收藏

94
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部