当前位置:网站首页 > 技术博客 > 正文

sqlserver触发器实例



sql server 触发器

例子

一﹕

触发器

是一种特殊的存储过程﹐它不能被显式地调用﹐而是在往表中插入记录﹑更新记录或者删除记录时被自动地激活。所以

触发器

可以用来实现对表实施

复杂

的完整性约`束。

二﹕

SQL Server

为每个

触发器

都创建了两个专用表﹕Inserted表和Deleted表。这两个表由系统来维护﹐它们存在于内存中而不是在

数据库

中。这两个表的结构总是与被该

触发器

作用的表的结构相同。

触发器

执行 完成后﹐与该

触发器

相关的这两个表也被删除。

Deleted表存放由于执行Delete或Update语句而要从表中删除的所有行。

Inserted表存放由于执行Insert或Update语句而要向表中插入的所有行。

三﹕Instead of 和 After

触发器 SQL Server

2000提供了两种

触发器

﹕Instead of 和After

触发器

。这两种

触发器

的差别在于他们被激活的同﹕

Instead of

触发器

用于替代引起

触发器

执行的T-

SQL

语句。除表之外﹐Instead of

触发器

也可以用于视图﹐用来扩展视图可以支持的更新操作。

After

触发器

在一个Insert,Update或Deleted语句之后执行﹐进行约束检查等动作都在After

触发器

被激活之前发生。After

触发器

只能用于表。

一个表或视图的每一个修改动作(insert,update和delete)都可以有一个instead of

触发器

﹐一个表的每个修改动作都可以有多个After

触发器

四﹕

触发器

的执行过程

如果一个Insert﹑update或者delete语句违反了约束﹐那幺After

触发器

不会执行﹐因为对约束的检查是在After

触发器

被激动之前发生的。所以After

触发器

不能超越约束。

Instead of

触发器

可以取代激发它的操作来执行。它在Inserted表和Deleted表刚刚建立﹐其它任何操作还没有发生时被执行。因为Instead of

触发器

在约束之前执行﹐所以它可以对约束进行一些预处理。

五﹕使用T-

SQL

语句来创建

触发器

基本语句如下﹕

create

trigger trigger

_name

on {table_name | view_name}

{for | After | Instead of }

[ insert, update,delete ]

as

sql

_statement

六﹕相关示例﹕

1﹕在Orders表中建立

触发器

﹐当向Orders表中插入一条订单记录时﹐检查goods表的货品状态status是否为1(正在整理)﹐是﹐则不能往Orders表加入该订单。

create

trigger

orderinsert

on orders

after insert

as

if (select status from goods,inserted

where goods.name=inserted.goodsname)=1

begin

print 'the goods is being processed'

print 'the order cannot be committed'

rollback transaction --回滚﹐避免加入

end

2﹕在Orders表建立一个插入

触发器

﹐在添加一条订单时﹐减少Goods表相应的货品记录中的库存。

create

trigger

orderinsert1

on orders

after insert

as

update goods set storage=storage-inserted.quantity

from goods,inserted

where

goods.name=inserted.goodsname

3﹕在Goods表建立删除

触发器

﹐实现Goods表和Orders表的级联删除。

create

trigger

goodsdelete

on goods

after delete

as

delete from orders

where goodsname in

(select name from deleted)

4﹕在Orders表建立一个更新

触发器

﹐监视Orders表的订单日期(OrderDate)列﹐使其不能手工修改.

create

trigger

orderdateupdate

on orders

after update

as

if update(orderdate)

begin

raiserror(' orderdate cannot be modified',10,1)

rollback transaction

end

5﹕在Orders表建立一个插入

触发器

﹐保证向Orders表插入的货品名必须要在Goods表中一定存在。

create

trigger

orderinsert3

on orders

after insert

as

if (select count(*) from goods,inserted where goods.name=inserted.goodsname)=0

begin

print ' no entry in goods for this order'

rollback transaction

end

--insert

触发器

create

trigger

tri_infoDetails_i on info_details

after insert

as

declare @id int

begin

--delete from info_details where id=

select @id=id from inserted;

insert into info_details_index(TYPE,TITLE,content,POST_TIME,FLAG)

select type,title,content,getdate(),1 from info_details where id=@id;

--update info_details_index set content=content

end;

-- update

触发器

--select top 0 type,title,content,getdate() as post_time,1 as flag into info_details_index from info_details;

create

trigger

tri_infoDetails_u on info_details

after update

as

declare @id int

begin

if exists(select 1 from inserted)

if exists(select 1 from deleted)

begin

select @id=id from inserted;

insert into info_details_index(TYPE,TITLE,content,POST_TIME,FLAG)select type,title,content,getdate(),-1 from info_details where id=@id;

insert into info_details_index(TYPE,TITLE,content,POST_TIME,FLAG)select type,title,content,getdate(),1 from info_details where id=@id;

end

--update info_details_index set content=content

end

--delete

触发器

create

trigger

tri_infoDetails_d on info_details

after delete

as

declare @id int

begin

if exists(select 1 from deleted)

begin

insert into info_details_index(TYPE,TITLE, POST_TIME,FLAG)

select type,title, getdate(),-1 from deleted info_details ;

end

end

版权声明


相关文章:

  • c解析json数据的代码2024-12-25 14:30:03
  • java程序设计之网络编程2024-12-25 14:30:03
  • 函数已有主体是什么意思2024-12-25 14:30:03
  • 分词器有哪些2024-12-25 14:30:03
  • c中clr是什么意思2024-12-25 14:30:03
  • 虚拟机安装软件2024-12-25 14:30:03
  • 电脑阅读软件哪个好用2024-12-25 14:30:03
  • rapid recompile2024-12-25 14:30:03
  • dbcp object created2024-12-25 14:30:03
  • 使用usermod命令修改用户账号名称2024-12-25 14:30:03