博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server insert的触发器
阅读量:6227 次
发布时间:2019-06-21

本文共 1988 字,大约阅读时间需要 6 分钟。

SQL Server insert的触发器

一张表a根据一列(唯一键或主键)a1当插入数据时判断该列a1的开头的字符是否为:'0150'

若是则更新该表a的a2列为:'-10'

a表

CREATE TABLE a(

a1 nvarchar(50) NULL,
a2 int NULL
)

 

select * from a
truncate table a

 

该触发器一次只能插入一行

create trigger tri_insert_a

on a
after insert
as
begin
if (select a.a1 from a, inserted
where a.a1 = inserted.a1 and a.a1) like '0150%'
begin
update a set a2='-10'
from a, inserted
where a.a1 = inserted.a1
and a.a1 like '0150%'
end
end

 

drop trigger tri_insert_a

 

一次插入多行

create trigger tri_insert_a
on a
after insert
as
begin
if exists(select a.a1 from a, inserted
where a.a1 = inserted.a1 and a.a1 like '0150%')
begin
update a set a2='-10'
from a, inserted
where a.a1 = inserted.a1
and a.a1 like '0150%'
end
end

drop trigger tri_insert_a

select * from a

 

修改触发器

alter trigger tri_insert_a
on a
after insert
as
begin
if exists(select a.a1 from a, inserted
where a.a1 = inserted.a1 and a.a1
like '0150%')
begin
update a set a2='-10'
from a, inserted
where a.a1 = inserted.a1
and a.a1 like '0150%'
end
end

创建触发器语法
create trigger trigger_name
on {table_name|view_name}
{After|Instead of} {insert|update|delete}
as 相应T-SQL语句

其中关于触发器有时会遇到for替代after的情况,for 和 after 没有区别。

for 不是before,sqlserver只有instead和after两种触发器。默认是after的。
for 不是同步,也不是BEFORE,是触发器默认的触发点,默认为AFTER,能用就用AFTER,
因为for 的话要编译转换一下后变成after,
所以for 比after 效率低一点点吧

还有经常遇到 insert table_a select * from table_b 这样的语句,
同时在表table_a中根据每一条新增的SQL语句,通过触发器来触发对应的一系列的后续操作.
分析:
实际上insert触发器,在每次SQL语句中只会影响到第一条的语句
如果触发器被启用,触发器对每个批处理执行一次。
触发器是针对一个事务而言,而不是根据数据记录来做触发的。
inserted,deleted是可以当作是临时表,但不是一条记录的临时表,而是批处理的临时表(一个事务的临时表)

 

参考文档:

关于MSDN《了解 DML 触发器》

http://blog.csdn.net/jinjazz/article/details/3420299

SQL Server:触发器详解
http://www.cnblogs.com/rainman/p/3675834.html

SQL Server 触发器
http://www.cnblogs.com/hoojo/archive/2011/07/20/2111316.html

【SQL Server】SQL触发器经验详解
http://jingyan.baidu.com/article/77b8dc7f2b82416175eab65b.html

可遇不可求的Question之SQLSERVER触发器不支持多行插入操作篇
http://www.cnblogs.com/tigerjacky/p/1987913.html

 

转载于:https://www.cnblogs.com/hw-1015/p/6605838.html

你可能感兴趣的文章
以太网类型汇总
查看>>
什么是Floating (浮动)规则?
查看>>
交换机端口设置为镜像导致网络不通
查看>>
Linux高负载下优化MYSQL
查看>>
Binder服务-底层驱动
查看>>
国内外一些ip反查域名的网站
查看>>
迪普防毒墙产品线
查看>>
sublime Text技巧
查看>>
mysql配置参数详解
查看>>
百万级SQL查询优化
查看>>
linux SWAP 分区建立及释放内存
查看>>
Rocks 头结点更改public IP 上网IP地址
查看>>
phpcmsv9 调用多个栏目下文章的两个办法
查看>>
LINUX帐号管理命令简介
查看>>
oracledatabase12g.com目前使用的wordpress插件
查看>>
Python random模块
查看>>
nagios 详细部署操作(二)
查看>>
流程式编程
查看>>
小蚂蚁学习APP接口开发(5)—— APP接口实例——单例模式连接数据库
查看>>
windows7怎么设置并链接“L2TP ***”
查看>>