加入收藏 | 设为首页 | 会员中心 | 我要投稿 济南站长网 (https://www.0531zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2016-09-10 18:40:35 所属栏目:MsSql教程 来源:站长网
导读:添加,删除或修改数据库的对象,一旦误操作,可能会导致大麻烦,需要一个 数据库管理员或开发人员对相关可能受影响的实体进行代码的重写。 为了在数据库结构发
添加,删除或修改数据库的对象,一旦误操作,可能会导致大麻烦,需要一个 数据库管理员或开发人员对相关可能受影响的实体进行代码的重写。

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

(编辑:济南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读