SQL2005数据库中使用DDL触发器监控数据库变化_SQL SERVER数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

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

作者:黑客防线网安SQL维护基地 来源:黑客防线网安SQL维护基地 浏览次数:0

本篇关键词:数据库监控变化使用
黑客防线网安网讯:  添加,删除或修改数据库的对象,一旦误操作,可能会导致大麻烦,需要一个数据库管理员或开发人员对相关可能受影响的实体进行代码的重写。   为了在数据库结构发生变动而出现问题时,能...

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

  为了在数据库结构发生变动而出现问题时,能够跟踪问题,定位问题的根源,我们可以利用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级别的所有事件:

  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

    黑客防线网安服务器维护方案本篇连接:http://www.rongsen.com.cn/show-9622-1.html
网站维护教程更新时间:2012-03-21 02:23:21  【打印此页】  【关闭
我要申请本站N点 | 黑客防线官网 |  
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479

footer  footer  footer  footer