`

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

阅读更多

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

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

 

 

  USE AdventureWorks
  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事件的表在创建好之后,还需要建立一个DDL触发器,监控AdventureWorks数据库中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

 

分享到:
评论

相关推荐

    浅析SQL Server2005中的DDL触发器技术.pdf

    总之,DDL触发器技术是SQL Server 2005为了提升数据库安全性、实现数据库结构变化的精细控制而引入的重要特性。通过DDL触发器,数据库管理员可以对数据库结构的变更进行监控和管理,从而有效应对安全和审计上的挑战...

    基于sql server 2005的触发器的创建及操作

    2. DDL触发器:响应对数据库架构的改变,如CREATE、ALTER或DROP等操作,用来监控和控制数据库的结构变化。 二、创建触发器 1. 使用图形界面:在SQL Server Management Studio(SSMS)中,可以通过对象资源管理器...

    SQL Server 2005中触发器的应用.pdf

    DDL触发器是SQL Server 2005中的新特性,它能够响应数据定义语言(DDL)事件,如CREATE、ALTER和DROP语句。DDL触发器可用于数据库或服务器级别,其作用范围可以是单个DDL语句,也可以是一组DDL事件。DDL触发器提供了...

    SQL Server触发器在数据库系统开发中的应用研究.pdf

    SQL Server触发器是数据库管理系统中一种自动化执行SQL语句的存储程序,它在特定事件发生时被系统自动触发。触发器在数据库系统开发中有着极其重要的作用,尤其在确保数据完整性、数据库架构安全以及执行登录审计...

    数据库原理与应用教程:基于SQL+Server+2005.rar

    1. 分布式数据库:了解分布式数据库的概念,以及SQL Server 2005中的分布式查询和复制功能。 2. 数据仓库与BI:简单介绍数据仓库的构建,以及SQL Server Analysis Services (SSAS) 和Reporting Services (SSRS) 在...

    sqlserver 触发器学习(实现自动编号)

    在SQL Server中,触发器是一种特殊的存储过程,它在特定的数据库操作(如INSERT、UPDATE、DELETE)发生时自动执行,以实现复杂的数据完整性规则或业务逻辑。本篇将深入探讨触发器的基本概念、类型、分类及如何实现...

    使用SQL Server触发器实现数据表的级联更新.pdf

    在SQL Server中,有两种触发器:DDL触发器和DML触发器。DDL触发器是被数据定义语句(DDL)所触发而被调用的触发器;DML触发器是被数据操作语句(DML)所触发而被调用的触发器。数据完整性规则主要由DML触发器创建。 ...

    数据库原理与SQL Server2005应用教程

    数据库原理与SQL Server 2005应用教程是学习数据库管理和开发的重要参考资料,尤其适合初学者及希望深入了解SQL Server 2005的用户。本教程由一位经验丰富的数据库教授编写,旨在帮助读者掌握数据库的基本概念,理解...

    SQL Server 2005数据库简明教程

    SQL Server 2005是微软公司推出的一款关系型数据库管理系统,它在企业级数据管理、分析和报告方面表现出色。本教程旨在帮助初学者快速理解并熟练掌握SQL Server 2005的核心功能和使用技巧。 一、SQL Server 2005...

    SQL Server 2005数据库

    2. 系统监控:使用SQL Server Management Studio(SSMS)监控数据库性能,调整索引、统计信息和硬件资源。 本教程"SQL Server 2005数据库基础及应用技术教程与实训电子教案"将通过实例教学,帮助学习者掌握SQL ...

    触发器在SQL Server2005中的使用.pdf

    触发器能够增强数据的完整性和约束性,可以在插入、更新或删除数据时自动执行,并且在SQL Server 2005中,还可以在创建、修改或删除数据表时自动激活执行。 触发器的特殊性在于它能够响应特定的事件,如DML(数据...

    SQLServer2005数据库学习指导教程,数据库基础知识,VB与数据库

    在IT领域,数据库是至关重要的组成部分,特别是在企业级应用中,SQL Server 2005作为微软公司推出的数据库管理系统,其稳定性和强大的功能受到了广泛的认可。这篇教程将深入讲解SQL Server 2005的基本概念、操作以及...

    SQL Server 2005数据库电子教材

    在SQL Server 2005中,通过DDL触发器和DML触发器,可以实现对数据完整性和业务规则的强制。学习如何创建、修改和删除触发器,以及如何避免触发器滥用导致的性能问题至关重要。 3. **权限管理**: 权限管理是SQL ...

    SQL Server 2005内置工具建审查系统

    在SQL Server 2005中,使用DDL触发器创建审查索引的过程涉及编写触发器脚本。例如,下面的脚本创建一个名为tr_Security的触发器,它会在服务器上监视所有的DDL登录事件,并将相关信息插入DDLTriggerTest表中。触发器...

    数据库SQL Server 2005的技术及应用

    SQL Server 2005支持标准的SQL语法,包括DML(Data Manipulation Language)用于插入、更新和删除数据,DDL(Data Definition Language)用于创建和修改表、视图等数据库对象,以及T-SQL(Transact-SQL)扩展,提供...

    sqlserver2005数据库开发教程(一)

    在本教程中,我们将深入探讨SQL Server 2005这一强大的关系型数据库管理系统,它在数据存储、处理和分析方面扮演着至关重要的角色。SQL Server 2005是微软公司推出的一个全面的企业级数据库解决方案,适用于各种规模...

    SQL Server数据库中触发器的应用研究.pdf

    DDL触发器用于监控数据库架构的操作,防止未授权的结构变更。 3. 登录触发器:在登录验证之后、用户会话建立之前触发,适用于执行登录时的附加操作。 创建触发器的方法: 创建触发器的语法结构如下: CREATE ...

    SQL server2008存储过程与触发器

    在SQL Server 2008中,存储过程和触发器是两种非常重要的数据库对象,它们在数据管理和业务逻辑实现上发挥着关键作用。下面将详细阐述这两个概念以及它们的应用。 **存储过程(Stored Procedures)** 1. **定义**:...

    SQL Server 2005产品家族.pdf

    本篇主要关注SQL Server 2005中的一个重要特性——DDL触发器,以及它在数据库审计和完整性方面的应用。 DDL触发器是一种特殊类型的触发器,它在数据库中定义数据定义语言(DDL)事件时自动执行,例如CREATE、ALTER...

Global site tag (gtag.js) - Google Analytics