SQL 学习 - 触发器
-
触发器定义
-
触发器用途
-
触发器语法
-
触发器心得
触发器定义
在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。类似于.NET中的事件函数
常见的触发器有三种:分别应用于Insert , Update , Delete 事件。
触发器用途
1. 触发器用来执行强制业务规则及数据库完整性
2. 表中插入、更新、删除记录时,触发一个或一系列 T-SQL语句。
3. 降低Web服务器压力,将一部分逻辑转到数据服务器
4. 减轻编程的工作量
触发器语法
触发器的基础知识和例子
create trigger tr_name
on table/view
{for | after | instead of } [update][,][insert][,][delete]
[with encryption]
as {batch | if update (col_name) [{and|or} update (col_name)] }
说明:
1. tr_name :触发器名称
2. on table/view :触发器所作用的表。一个触发器只能作用于一个表
3. for 和after :同义
4. after 与instead of :sql 2000新增项目afrer 与 instead of 的区别
After
在触发事件发生以后才被激活,只可以建立在表上
Instead of
代替了相应的触发事件而被执行,既可以建立在表上也可以建立在视图上
5. insert、update、delete:激活触发器的三种操作,可以同时执行,也可选其一
6. if update (col_name):表明所作的操作对指定列是否有影响,有影响,则激活触发器。此外,因为delete 操作只对行有影响, 所以如果使用delete操作就不能用这条语句了(虽然使用也不出错,但是不能激活触发器,没意义)。
7. 触发器执行时用到的两个特殊表:deleted ,inserted
deleted 和inserted 可以说是一种特殊的临时表,是在进行激活触发器时由系统自动生成的,其结构与触发器作用的表结构是一样的,只是存放的数据有差异。
触发器心得
1. 触发器的关键: 2个临时的表;触发机制。
2. 数据库报表(统计数据)字段常用,如:总金额=单价*数目
3. 触发器可以放在View上
4. 数据的完整性尽量使用约束,特殊情况除外(特殊情况也就是生活中很难遇到)
浙公网安备 33010602011771号