关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » SQL Server »用SQL Server 2005DDL触发器对数据库进行监控

    用SQL Server 2005DDL触发器对数据库进行监控

    2010-07-23 15:26:00 出处:ITJS
    分享

    以下的文章主要向大家讲述的是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函数是用来消除使用SSMS脚本向导时所带来的回车。

    第三步,一旦建立了表和触发器,我们就可以用以下的操作,来测试看看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 

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

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

    图1: AuditLog日志表查询结果

    (4)小结

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

    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    电脑屏幕不小心竖起来了?别慌,快捷键搞定

    Destoon 模板存放规则及语法参考

    Destoon系统常量与变量

    Destoon系统目录文件结构说明

    Destoon 系统安装指南

    Destoon会员公司主页模板风格添加方法

    Destoon 二次开发入门

    Microsoft 将于 2026 年 10 月终止对 Windows 11 SE 的支持

    Windows 11 存储感知如何设置?了解Windows 11 存储感知开启的好处

    Windows 11 24H2 更新灾难:系统升级了,SSD固态盘不见了...

    IT头条

    Synology 更新 ActiveProtect Manager 1.1 以增强企业网络弹性和合规性

    00:43

    新的 Rubrik Agent Cloud 加速了可信的企业 AI 代理部署

    00:34

    宇树科技 G1人形机器人,拉动一辆重达1.4吨的汽车

    00:21

    Cloudera 调查发现,96% 的企业已将 AI 集成到核心业务流程中,这表明 AI 已从竞争优势转变为强制性实践

    02:05

    投资者反对马斯克 1 万亿美元薪酬方案,要求重组特斯拉董事会

    01:18

    技术热点

    大型网站的 HTTPS 实践(三):基于协议和配置的优化

    ubuntu下右键菜单添加新建word、excel文档等快捷方式

    Sublime Text 简明教程

    用户定义SQL Server函数的描述

    怎么在windows 7开始菜单中添加下载选项?

    SQL Server 2016将有哪些功能改进?

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。