结合触发器和事务处理
触发器和事务是一个强有力的结合。你可以使用语句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 倒转回去。