数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

SQL Server触发器创建、删除、修改、查看


发布日期:2021年12月08日
 
SQL Server触发器创建、删除、修改、查看

触发器是一种特殊的存储过程它不能被显式地调用而是在往表中插入记录﹑更新记录或者删除记录时被自动地激活所以触发器可以用来实现对表实施复杂的完整性约束

SQL Server为每个触发器都创建了两个专用表Inserted表和Deleted表这两个表由系统来维护它们存在于内存中而不是在数据库中这两个表的结构总是与被该触发器作用的表的结构相同触发器执行 完成后与该触发器相关的这两个表也被删除

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

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

Instead of 和 After触发器

SQL Server提供了两种触发器Instead of 和After 触发器这两种触发器的差别在于他们被激活的同

Instead of触发器用于替代引起触发器执行的TSQL语句除表之外Instead of 触发器也可以用于视图用来扩展视图可以支持的更新操作

After触发器在一个InsertUpdate或Deleted语句之后执行进行约束检查等动作都在After触发器被激活之前发生After触发器只能用于表

一个表或视图的每一个修改动作(insertupdate和delete)都可以有一个instead of 触发器一个表的每个修改动作都可以有多个After触发器

触发器的执行过程

如果一个Insert﹑update或者delete语句违反了约束那幺After触发器不会执行因为对约束的检查是在After触发器被激动之前发生的所以After触发器不能超越约束

Instead of 触发器可以取代激发它的操作来执行它在Inserted表和Deleted表刚刚建立其它任何操作还没有发生时被执行因为Instead of 触发器在约束之前执行所以它可以对约束进行一些预处理

使用TSQL语句来创建触发器

基本语句如下

create trigger trigger_name

on {table_name | view_name}

{for | After | Instead of }

[ insert updatedelete ]

as

sql_statement

删除触发器

基本语句如下

drop trigger trigger_name

查看数据库中已有触发器

查看数据库已有触发器

use jxcSoftware

go

select * from sysobjects where xtype=TR

查看单个触发器

exec sp_helptext 触发器名

修改触发器

基本语句如下

alter trigger trigger_name

on {table_name | view_name}

{for | After | Instead of }

[ insert updatedelete ]

as

sql_statement

相关示例

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

create trigger orderinsert

on orders

after insert

as

if (select status from goodsinserted

where goodsname=insertedgoodsname)=

begin

print the goods is being processed

print the order cannot be committed

rollback transaction 回滚避免加入

end

在Orders表建立一个插入触发器在添加一条订单时减少Goods表相应的货品记录中的库存

create trigger orderinsert

on orders

after insert

as

update goods set storage=storageinsertedquantity

from goodsinserted

where

goodsname=insertedgoodsname

在Goods表建立删除触发器实现Goods表和Orders表的级联删除

create trigger goodsdelete

on goods

after delete

as

delete from orders

where goodsname in

(select name from deleted)

在Orders表建立一个更新触发器监视Orders表的订单日期(OrderDate)列使其不能手工修改

create trigger orderdateupdate

on orders

after update

as

if update(orderdate)

begin

raiserror( orderdate cannot be modified)

rollback transaction

end

在Orders表建立一个插入触发器保证向Orders表插入的货品名必须要在Goods表中一定存在

create trigger orderinsert

on orders

after insert

as

if (select count(*) from goodsinserted where goodsname=insertedgoodsname)=

begin

print no entry in goods for this order

rollback transaction

end

Orders表建立一个插入触发器保证向Orders表插入的货品信息要在Order表中添加

alter trigger addOrder

on Orders

for insert

as

insert into Order

select insertedId insertedgoodNameinsertedNumber from inserted

               

上一篇:用VFP的DBF进行SQL Server的分布式查询

下一篇:获得XML格式的SQL Server图表结构