时间:2021-07-01 10:21:17 帮助过:4人阅读
触发器分为两大类:
DML触发器:
DDL触发器当服务器或者数据库中发生数据操纵语言(DML)事件时将被调用,
主要包括四种类型:
DELETE 触发器
INSERT 触发器
UPDATE 触发器
INSTEAD OF 触发器
DDL触发器:
DDL触发器当服务器或者数据库中发生数据定义语言(DDL)事件时将被调用
创建DML触发器语法:
CREATE TRIGGER [schema_name.]trigger_name ON {table | view} [WITH ENCRYPTION] {FOR | AFTER | INSTEAD OF} {[INSERT] [,] [UPDATE] [,] [DELETE]} AS {sql_statement [;] }
WITH ENCRYPTION表示加密触发器定义的SQL文本 DELETE, INSERT, UPDATE指定触发器的类型 INSTEAD OF一般用于视图
触发器触发时: 系统自动在内存中创建deleted表或inserted表 只读,不允许修改;触发器执行完成后,自动删除
问题: 解决上述的银行取款问题:当向交易信息表(transInfo)中插入一条交易信息时,我们应自动更新对应帐户的余额。
分析: 在交易信息表上创建INSERT触发器 从inserted临时表中获取插入的数据行 根据交易类型(transType)字段的值是存入/支取, 增加/减少对应帐户的余额。
-------关键代码------ CREATE TRIGGER trig_transInfo ON transInfo FOR INSERT AS DECLARE @type char(4),@outMoney MONEY DECLARE @myCardID char(10),@balance MONEY SELECT @type=transType,@outMoney=transMoney, @myCardID=cardID FROM inserted IF (@type=‘支取‘) UPDATE bank SET currentMoney=currentMoney-@outMoney WHERE cardID=@myCardID ELSE UPDATE bank SET currentMoney=currentMoney+@outMoney WHERE cardID=@myCardID ….. GO
小结
触发器是在对表进行插入、更新或删除操作时自动执行的存储过程,
触发器通常用于强制业务规则
触发器还是一个特殊的事务单元,当出现错误时,可以执行ROLLBACK TRANSACTION回滚撤销操作
触发器一般都需要使用临时表:deleted表和inserted表,它们存放了被删除或插入的记录行副本
触发器类型: DML触发器 DDL触发器
数据库 触发器
标签: