您的位置:首页 > 博客中心 > 数据库 >

SQL触发器实例讲解

时间:2022-03-15 08:48

何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程

SQL触发器实例1 
定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的过程。 
常见的触发器有三种:分别应用于Insert , Update , Delete 事件。 
我为什么要使用触发器?比如,这么两个表: 

gxlsystem.com,布布扣

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

热门排行

今日推荐

热门手游