SQL触发器实例讲解
时间:2022-03-15 08:48
何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程
SQL触发器实例1
定义: 何为触发器?在SQL
Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的过程。
常见的触发器有三种:分别应用于Insert
, Update , Delete
事件。
我为什么要使用触发器?比如,这么两个表:
4、关于触发器,还应该注意
(1)、DELETE 触发器不能捕获 TRUNCATE TABLE
语句。
(2)、触发器中不允许以下 Transact-SQL
语句:
ALTER DATABASE CREATE DATABASE DISK
INIT
DISK RESIZE DROP DATABASE LOAD
DATABASE
LOAD LOG RECONFIGURE RESTORE
DATABASE
RESTORE LOG
(3)、触发器最多可以嵌套
32
层。
*/
--修改触发器
--实质上,是将
CREATE TRIGGER ... 修改为 ALTER TRIGGER
...即可。
--删除触发器
DROP TRIGGER
xxx
GO
--删除测试环境
DROP
TABLE 卷烟库存表
GO
DROP TABLE
卷烟销售表
GO
DROP TRIGGER
T_INSERT_卷烟库存表
GO
DROP TRIGGER
T_INSERT_卷烟销售表
GO
##################################################################
触发器的基础知识和例子
: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
可以说是一种特殊的临时表,是在进行激活触发器时由系统自动生成的,其结构与触发器作用的表结构是一
样的,只是存放
的数据有差异。
续
下面表格说明deleted 与inserted
数据的差异
deleted 与inserted
数据的差异
Inserted
存放进行insert和update
操作后的数据
Deleted
存放进行delete
和update操作前的数据
注意:update 操作相当于先进行delete 再进行insert
,所以在进行update操作时,修改前的数据拷贝一条到deleted
表中,修改后
的数据在存到触发器作用的表的同时,也同时生成一条拷贝到insered表中
SQL触发器实例讲解,布布扣,bubuko.com