结合触发器和事务处理

发表于:2007-06-30来源:作者:点击数: 标签:
结合触发器和事务处理 触发器和事务是一个强有力的结合。你可以使用语句ROLLBACK TRANSACTION来取消触发触发器的动作。考察下面的触发器: CREATE TRIGGER tr_webusers ON webusers FOR INSERT,UPDATE,DELETE AS IF DATENAME(dw,GE TD ATE())=”Tuesday” RO

结合触发器和事务处理

触发器和事务是一个强有力的结合。你可以使用语句ROLLBACK TRANSACTION来取消触发触发器的动作。考察下面的触发器:

CREATE TRIGGER tr_webusers ON webusers FOR INSERT,UPDATE,DELETE AS

IF DATENAME(dw,GETDATE())=”Tuesday”

ROLLBACK TRANSACTION

该触发器阻止任何人在星期二向表webusers内插入新的记录,删除记录或修改记录。如果你企图在星期二向表中添加新记录,该动作会被语句ROLLBACK TRANSACTION回转回去。

假如你目前正为如何阻止某一个特定的人访问你的网站而困惑。你不想让这个家伙能够在你的网站上注册。为了做到这一点,你可以创建一个和表webusers相关的触发器,该触发器用于检查这个家伙的姓名,如下所示:

CREATE TRIGGER tr_webusers FOR INSERT,DELETE,UPDATE AS

IF EXISTS(SELECT user_name FROM Inserted WHERE user_name=”Andrew Jones”)

ROLLBACK TRANSACTION

该触发器阻止姓名为Andrew Jones的人添加入表webusers内,当姓名Andrew Jones包含在某个INSERT,DELETE或UPDATE语句内时,该动作就会被语句ROLLBACK TRANSACTION 倒转回去。

原文转自:http://www.ltesting.net