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.      数据的完整性尽量使用约束,特殊情况除外(特殊情况也就是生活中很难遇到)

 

posted @ 2011-03-14 10:32  树上有鱼  阅读(146)  评论(0)    收藏  举报