您的位置首页 > 文化 > 图书 > sql触发器

sql触发器,SQL中的“触发器”是什么?

2020-10-03     105    

盘痴柏钱州 SQL中的“触发器”是什么? 2018-01-30

触发器是对表进行插入、更新、删除的时候会自动执行的特殊存储过程。 触发器一般用在check约束更加复杂的约束上面。例如在执行update、insert、delete这些操作...

qsc800528 SQL中,触发器是什么? 2015-03-24

触发器是对表进行插入、更新、删除的时候会自动执行的特殊存储过程。 触发器一般用在check约束更加复杂的约束上面。例如在执行update、insert、delete这些操作...

anonymous SQl中触发器怎样执行的? 2019-07-12

创建触发器 是特殊的存储过程,自动执行,一般不要有返回值。 1、后触发器 (AFTER,FOR)先执行对应语句,后执行触发器中的语句。 2、前触发器 并没有...

Ice_swordman SQL触发器写法 2015-12-05

基本语法 create trigger tri_name on table for insert/update/deleted as SQL code 例: create trigger tri_mc(tri_mc:自定义触发器的名称) on ...

长映谏莹 SQL触发器如何使用 2010-03-01

CREATE TRIGGER 创建触发器,触发器是一种特殊的存储过程,在用户试图对指定的表执行指定的数据修改语句时自动执行。Microsoft® SQL Server™ 允许...

神说早安 什么是触发器?SQL中的哪几种操作会触发触发器? 2010-11-24

触发器(trigger)是个特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会...

豆新台问筠 SQL触发器编写 2019-08-02

基本语法 create trigger tri_name on table for insert/update/deleted as SQL code 例: create trigger tri_mc(tri_mc:自定义触发器的名称) on ...

234501789 sql 增加 触发器 2018-09-12

drop TRIGGER if EXISTS insert_data; create trigger insert_data after INSERT on a for each ROW BEGIN insert into b select * from a order by...

psteam SQLSERVER中触发器的触发类型有几种? 2020-05-19

SQL SERVER中触发器的触发类型有三种。 1、DML触发器,当数据库中表中的数据发生变化时,包括insert,update,delete任意操作,如果对该表写了对应的DML触发...

yaj52125 SQL触发器 2009-12-09

create trigger tri_1 on 药品 for delete as delete from 药品 where 编号 in(select 编号 from 药品 where 编号 in(select 编号 from 处方) if ...

 

本人水平有限,写此博客只为给那些像我一样的菜鸟一点小小的帮助,还请各位大牛不要见笑。

数据库的重要性就不用我多说了吧,我们做的大多数项目都要跟数据库打交道。因此,熟练掌握数据库的各种操作,就成了一个程序员必备的技能。今天我们就来简单说一下触发器。

 

触发器简介:
 

触发器(trigger)是种特殊的存储过程,它的执行不是由程序调用,也不需yao手动操作,它是由事件来触发,事件大家应该非常熟悉吧,比如按钮的Click事件、网页的Load事件等。按钮的Click事件是通过鼠标单击按钮触发的,而触发器的事件,是由对表进行增删改操作所触发的。当对一个数据库或表进行增删改( Insert,Delete,Update)的时就会激活触发器。  www.2cto.com  
 

从SQL2005开始,根据SQL语句的不同将触发器分成了两类,一类是DML触发器,一类是DLL触发器。其中DML触发器又分为两类:After触发器和Instead Of触发器。

 

触发器的分类:
 

DML触发器:DML(Data Manipulation Language)触发器是当数据库服务器中发生数据操作语言事件时执行的存储过程。DML触发器又分为两类:After触发器和Instead Of触发器

DDL触发器:DDL触发器是在响应数据定义语言(Data Definition Language)事件时执行的存储过程。DDL触发器一般用于执行数据库中管理任务。如审核和规范数据库操作、防止数据库表结构被修改等。

 

DML触发器:
 

今天我们我们主要介绍DML触发器,DML触发器分为After触发器和Instead Of触发器。

After触发器:这类触发器是在记录已经改变完之后(after),才会被激活执行,它主要是用于记录变更后的处理或检cha,一旦发现错误,也可以用Rollback Transaction语句来回滚本次的操作。

Instead Of触发器:这类触发器一般是用来取代原本的操作,在记录变更之前发生的,它并不去执行原来SQL语句里的操作(Insert、Update、Delete),而去执行触发器本身所定义的操作。
 

在SQL Server里,每个DML触发器都分配有两个特殊的表,一个是Inserted表,一个是Deleted表。它们两个存在于数据库服务器的内存中,是由系统管理的逻辑表,是两个临时表,而不是真正存储在数据库中的物理表。用户对这两个表只有读取的权限,没有修改的权限。

这两个表的结构(主外键、字段、数据类型等)与触发器所在数据表的结构是完全一致的,当触发器的工作完成之后,这两个表也将会从内存中删除。

 

Inserted和Deleted两个表的作用:
 

Inserted:对于插入记录操作来说,插入表里存放的是要插入的数据;对于更新记录操作来说,插入表里存放的是要更新的记录。

Deleted:对于更新记录操作来说,删除表里存放的是被更新记录;对于删除记录操作来说,删除表里存入的是被删除的旧记录。  www.2cto.com  

 

看上面两句话可能不太明白,那么看看下面这张表是不是就明白了?

 

 

工作原理:

 

After触发器的工作原理:

 

After触发器是在SQL语句执行之后才被激活的。以删除记录为例:当SQL Server接收到一条删除操作的SQL语句时,SQL Server先将要删除的记录存放在Deleted表里,然后把数据表里的记录删除,再激活After触发器,执行After触发器里的SQL语句。执行完毕之后, 删除内存中的Deleted表,操作结束。

还是举上面的例子:在产品库存表里,如果要删除一条产品记录,在删除的时候,触发器可以检cha该产品库存数量是否为零,如果不为零则取消删除操作。数据库的操作如下:
 

1,接收SQL语句,将要从产品库存表里删除的产品记录取出来,放在删除表里。

2,从产品库存表里删除该产品记录。

3,从删除表里读出该产品的库存数量字段,判断是不是为零,如果为零的话,完成操作,从内存里清除删除表;如果不为零的话,用Rollback Transaction语句来回滚操作(即将库存表还原成删除之前的状态)。

 

Instead Of 触发器的工作原理:

 

Instead Of触发器与After触发器不同。After触发器是在Insert、Update和Delete操作完成后才激活的,而Instead Of触发器,是在这些操作进行之前就激活了,并且不再去执行原来的SQL操作,而是用触发器本身的SQL语句代替原来的语句去执行。

还拿上面那个例子来说,删除一条产品记录的时候,用Instead Of将删除操作替换成查询该产品的库存。数据库的操作如下:
 

1,接收SQL语句,但不执行,而是跳转到Instead Of后面的SQL语句

2,根据传入的产品ID,将该产品的库存取出,完成操作。

 

说了那么多理论上的东西,下面让我们看看触发器的代码到底怎么写:

 

下面的一段代码是触发器的一个框架。

 

CREATE TRIGGER  Trigger_Name --触发器名,在一个数据库中触发器名是唯一的。

 

   ON  Table_Name | View_Name --触发器所在的表或者视图。

 

   AFTER(FOR)|Instead Of  INSERT,DELETE,UPDATE --定义成AFTER或Instead Of类型的触发器。

   

   --AFTER跟FOR相同,不可在视图上定义AFTER触发器

   

   -- 后面是触发器被触发的条件,最少有一个,可以邮多个。如果有多个用逗号分开,顺序无要求。  www.2cto.com  

 

AS --触发器要执行的操作

 

BEGIN

 

   --BEGIN跟END组成一个代码块,可以写也可以不写,如果触发器中执行的SQL语句比较复杂,用BEGIN和END会让代码更加整齐,更容易理解。

 

END

GO --GO就代表结操作完毕

 

注意事项:  www.2cto.com  

 

1,After触发器只能用于数据表不能用于视图;Instead Of触发器两者皆可,设置为With Check Option的视图也不允许建立Instead Of触发器。两种触发器都不可以建立在临时表上。

2,一个数据表可以有多个触发器,但是一个触发器只能对应一个表。

3,在同一个数据表中,对每个操作(如Insert、Update、Delete)而言可以建立许多个After触发器,而Instead Of触发器针对每个操作只有建立一个。

4,如果针对某个操作即设置了After触发器又设置了Instead Of触发器,那么Instead of触发器一定会激活,而After触发器就不一定会激活。
 

5,不同的SQL语句,可以触发同一个触发器,如Insert和Update语句都可以激活同一个触发器。

6,触发器名在所在的数据库里必须是唯一的。由于触发器是建立中数据表或视图中的,所以有很多人都以为只要是在不同的数据表中,触发器的名称就可以相同,其实触发器的全名(Server.Database.Owner.TriggerName)是必须 唯一的,这与触发器在哪个数据表或视图无关。

7,关键字AFTER可以用For来代取,它们的意思都是一样的,代表只有在数据表的操作都已正确完成后才会激活的触发器。

 

 

 

作者 刘水镜

文化图书相关阅读
标签大全 | 网站地图 | RSS订阅 | 返回顶部