2005DDL触发器对数据库进行监控-用SQL-Server (2005多大了属什么的)

教程大全 2025-07-17 15:49:43 浏览

以下的文章主要向大家讲述的是Sql Server 2005DDL触发器监控数据库的相关变化,添加,删除或是修改数据库的相关对象,一旦误操作,可能会导致大麻烦,需要一个数据库治理员或开发人员对相关可能受影响的实体进行代码的重写。

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

Server

(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操作记录:

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

使用 EVENTDATA 函数,可以捕捉有关激发 DDL 触发器的事件的信息,并将其保存到我们的AuditLog日志表中。EVENTDATA 函数的是返回 xml 值,采用以下的命令进行解析:

需要LTRIM和RTRIM是所有的左边的前导空格和右边的尾随空格,而REPLACE函数是用来消除使用SSMS脚本向导时所带来的回车。

第三步,一旦建立了表和触发器,我们就可以用以下的操作,来测试看看SQL Server 2005DDL触发器是否正常运行:

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

图1: AuditLog日志表查询结果

(4)小结

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

【编辑推荐】


关于Sql Server里面设置触发器

可以使用ddl触发器,下面的网址介绍的很详细了,请参照:补充:CREATE TRIGGER TEST_DDL_TRIGGER ON DATABASE FORALTER_TABLE ASBEGINRAISERROR(这个数据库不允许alter table操作!, 16, 1)ROLLBACKEND*************************---以上,希望对你有所帮助。

在sql中,创建DDL数据库级触发器,实现不能删除book表,但是可以删除其他表

是什么类型数据库,我先只说oralce的吧create or replace trigger ddl_checkbefore create or alter or drop or truncate on databasebegin-- sql语句end;应该是可以的。

SQL server 2005的触发器

--使用后置触发器删除ClassInfo表中的班级CREATE TRIGGER tri_ClassInfoON ClassInfoINSTEAD OF DELETEASDECLARE @CID INTSELECT @CID=C_ID FROM DELETED--删除约束 ALTER TABLE StuInfo DROP FK_CID ALTER TABLE ClassInfo DROP PK_CID--执行删除DELETE FROM StuInfo WHERE @CID=C_IDDELETE FROM ClassInfo WHERE @CID=C_IDCREATE TABLE ClassInfo( C_ID INT NOT NULL, C_Name VARCHAR(10) NOT NULL, C_Mount INT NOT NULL)--添加主键约束ALTER TABLE ClassInfoADD CONSTRAINT PK_CID PRIMARY KEY(C_ID)CREATE TABLE StuInfo( S_ID INT IDENTITY(1,1), S_Name VARCHAR(20) NOT NULL, C_ID INT NOT NULL)--添加主键和外键约束ALTER TABLE StuInfoADD CONSTRAINT PK_SID PRIMARY KEY(S_ID)ALTER TABLE StuInfoADD CONSTRAINT FK_CID FOREIGN KEY(C_ID) REFERENCES ClassInfo

--创建约束 ALTER TABLE ClassInfo ADD CONSTRAINT PK_CID PRIMARY KEY(C_ID) ALTER TABLE StuInfo ADD CONSTRAINT FK_CID FOREIGN KEY(C_ID) REFERENCES ClassInfoGO

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐