在SQL Server 中使用EVENTDATA()函数来获取DDL 触发器信息
2009-07-08 16:54
453 查看
SQL Server 2005/2008中可以使用EVENTDATA函数来获取DDL触发器的上下文,从而在ROLLBACK之前截获DDL信息。EVENTDATA返回XML字段,下面的例子显示如何截获Drop Table的DDL信息。
执行如下删除操作:
DROP TABLE TableToDelete
会触发上面的DDL,从而回滚操作。
执行下面的Sql:
SELECT * FROM TriggerLog
查看刚才截获的DDL信息。
转载请注明:
本文原创自CSDN TJVictor专栏:
http://blog.csdn.net/tjvictor/archive/2009/07/08/4331788.aspx
-- Create a log table CREATE TABLE TriggerLog (LogInfo xml) -- Create a dummy table to delete later on CREATE TABLE TableToDelete (Id int PRIMARY KEY) -- 新建一个新表,作为删除实验表 INSERT INTO TableToDelete VALUES(1) GO -- 创建一个Drop Table 的 DDL CREATE TRIGGER StopTableDrop ON DATABASE AFTER DROP_TABLE AS DECLARE @EventData AS xml SET @EventData = EVENTDATA() -- 必须要在rollback之前截获DDL信息 ROLLBACK PRINT 'DROP TABLE attempt in database ' + DB_NAME() + '.' INSERT INTO TriggerLog VALUES(@EventData)
执行如下删除操作:
DROP TABLE TableToDelete
会触发上面的DDL,从而回滚操作。
执行下面的Sql:
SELECT * FROM TriggerLog
查看刚才截获的DDL信息。
转载请注明:
本文原创自CSDN TJVictor专栏:
http://blog.csdn.net/tjvictor/archive/2009/07/08/4331788.aspx
相关文章推荐
- 在SQL Server 中使用EVENTDATA()函数来获取DDL 触发器信息
- SQLServer EVENTDATA()函数来获取DDL 触发器信息
- 使用 SQL Server DATEPART 函数来获取毫秒
- 使用gethostname()函数和gethostbyname()函数获取主机相关信息
- 使用API中的函数:NetUserEnum来枚举用户 NetUserGetInfo来获取用户的信息
- 获取Exe文件版本信息的函数(使用GetFileVersionInfo得到TFileVersionInfo结构体,包含12项内容)
- 第九篇:使用 lstat 函数获取文件信息
- 使用SQLDMO从SQL Server中获取信息
- 使用 SQL Server DATEPART 函数来获取毫秒
- 获取SQL Server 2000数据库和表空间使用信息
- 使用gethostname()函数和gethostbyname()函数获取主机相关信息
- 教你如何在 sql server 2005 使用 sql 语句获取字段的说明信息
- 在vb中使用Iphlpapi.dll获取网络信息 第四章 第二节 一个重要函数
- 使用gethostname()函数和gethostbyname()函数获取主机相关信息
- VS6.0下使用 IP Help API(Iphlpapi.dll)系列函数之GetAdaptersAddresses(GetAdaptersInfo) 获取网卡信息简述
- c# API使用GetVolumeInformation函数获取硬盘信息
- 在vb中使用Iphlpapi.dll获取网络信息 第三章 第一节 IPHLPAPI 的其它函数
- 获取SQL Server 2000数据库和表空间使用信息
- [Unity3D]使用OnGUI函数显示状态栏并且使用触发器修改玩家当前信息