问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

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

发布网友 发布时间:2023-05-17 06:53

我来回答

1个回答

热心网友 时间:2023-09-13 03:23


一:触发器是一种特殊的存储过程,它不能被显式地调用,而是在往表中插入记录_更新记录或者删除记录时被自动地激活。所以触发器可以用来实现对表实施复杂的完整性约束。
二:SQL Server为每个触发器都创建了两个专用表:Inserted表和Deleted表。这两个表由系统来维护,它们存在于内存中而不是在数据库中。这两个表的结构总是与被该触发器作用的表的结构相同。触发器执行 完成后,与该触发器相关的这两个表也被删除。
Deleted表存放由于执行Delete或Update语句而要从表中删除的所有行。
Inserted表存放由于执行Insert或Update语句而要向表中插入的所有行。
三:Instead of 和 After触发器
SQL Server2000提供了两种触发器: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
六:删除触发器:
基本语句如下:
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, 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
6:Orders表建立一个插入触发器,保证向Orders表插入的货品信息要在Order表中添加
alter trigger addOrder
on Orders
for insert
as
insert into Order
select inserted.Id, inserted.goodName,inserted.Number from inserted
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
胶原蛋白线双眼皮是不是永久性 双眼皮埋线是蛋白质还是尼龙绳-双眼皮埋线蛋白线多久能吸收 人体输液的“港口”完全植入式输液港 双眼皮宽变窄修复的方法 同心保家庭重疾险靠不靠谱?便宜吗? 做完双眼皮一宽一窄怎么办 喝全脂奶粉对长高有没有什么好处? redmine中“选择一个项目..."下拉列表框中为什么只列出一个项目,我建... 南充市龙门中学实力现在怎样?他的奥赛班是重点班么? 感情中为什么总是不知足呢? 关于钢筋代用的说法,错误的有()。 关于钢筋代换的说法,正确的有( )。(2011 年真题) 下列关于钢筋代换的说法,正确的有( )。 拼多多拼团的时候显示活动陆续开放中怎么回事 太阳倍数与leoc的关系是什么? 为什么我的电脑yy直播 显示cpu过高 惠普笔记本电脑,暗影精灵5,2060显卡。九代i7就一定比九代i5好么 韭菜炒虾仁 排骨猪骚味太重怎么办 单价和总价的公式 原癌基因与抑癌基因 ei基因失活的主要方式是 抑癌基因失活的途径 谁能把下面三点用高中水平知识解释一下,例如第一点我就没看明白了,拷贝失活是什么? 香港笼屋的栖身之地 香港笼屋 如何理解光线与波面的概念 光线的反义词_光线的近义词_光线的词语解释 tircks的翻译是:什么意思 人间用英语怎么说 人间英文 sql server 2008 如何设置 触发器 我不想用qq密保了怎么可以删除 qq密码设置了密保,想取消怎么做? 危言行见造朝时的解释危言行见造朝时的解释是什么 危言危行是什么意思解释 梦见家人和自己被鬼追跑了很远的预兆 对今年的新苹果BMP很失望,没有13'Retina屏幕,总抱着鸡肋光驱,想不通!又要等明年了。 贴片三极管上面标有大的13还有竖着小写的21这是什么三极管?型号是? BMP的基本数据 探店视频算纪录片吗 星尚频道2009年有一档探店节目叫什么 《召唤神龙》:一款小游戏把全体网友气得“高血压” 抖音主播玩的召唤神龙是真的吗 召唤神龙你上瘾了没? 乘风破浪的姐姐第二季郑秀妍的初舞台是哪一期 辨别单模和多模光纤收发器的区别方法 米小白机油滤芯怎么样 经典语录:眼泪流干后,要抬起头笑得很漂亮 伤感语录:能让你哭的人,总是那个能让你笑得很开心的人 梦见过河河水干的预兆