sql server里面的触发器怎么写?

找了个例程,竟然没看懂,希望各位老师提示一下:以下是例程定义:何为触发器?在SQLServer里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是... 找了个例程,竟然没看懂,希望各位老师提示一下:

以下是例程
定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。
常见的触发器有三种:分别应用于Insert , Update , Delete 事件。(SQL Server 2000定义了新的触发器,这里不提)

我为什么要使用触发器?
比如,这么两个表:
Create Table Student( --创建学生表
StudentID int primary key, --学号,定义主键约束
....
)

Create Table BorrowRecord( --创建借书记录表
BorrowRecord int identity(1,1), --自动增长流水号
StudentID int , --学号
BorrowDate datetime, --借出时间
ReturnDAte Datetime, --归还时间
...
)

用到的功能有:
如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借书记录表的学号);

这时候可以用到触发器。对于1,创建一个Update触发器:

Create Trigger truStudent
On Student
for Update --触发器类型--Update
-------------------------------------------------------
--Name:truStudent
--func:更新BorrowRecord 的StudentID,与Student同步。
--Use :None
--User:System
--Author: wp_love
--Date : 2003-4-16
--Memo : 临时写写的,给大家作个Sample。没有调试阿。
-------------------------------------------------------
As
if Update(StudentID)
begin

Update BorrowRecord
Set br.StudentID=i.StudentID
From BorrowRecord br , Deleted d ,Inserted i
Where br.StudentID=d.StudentID

end

理解触发器里面的两个临时的表:Deleted , Inserted 。注意Deleted 与Inserted分别表示触发事件的表“旧的一条记录”和“新的一条记录”。
一个Update 的过程可以看作为:生成新的记录到Inserted表,复制旧的记录到Deleted表,然后删除Student记录并写入新纪录。

上面那段代码中“br.StudentID=i.StudentID”,这br和i是怎么回事,能给讲讲吗?
展开
 我来答
MarsDingDing
2006-05-31 · TA获得超过207个赞
知道答主
回答量:84
采纳率:0%
帮助的人:110万
展开全部
仔细看看这段代码:
Update BorrowRecord
Set br.StudentID=i.StudentID
From BorrowRecord br , Deleted d ,Inserted i
Where br.StudentID=d.StudentID

From BorrowRecord br , Deleted d ,Inserted i
表示用别名br来代替BorrowRecord ,用d来代替Deleted,用d来代替Inserted。

明白了么?

Good Luck!
Sharon_QQ
2006-06-05 · TA获得超过492个赞
知道小有建树答主
回答量:362
采纳率:0%
帮助的人:372万
展开全部
Update BorrowRecord
Set br.StudentID=i.StudentID
From BorrowRecord br , Deleted d ,Inserted i
Where br.StudentID=d.StudentID

其中br代表当前查询表的别名,d代表在插入新值之前(即修改前)的表的别名,i代表在插入新值之后(即修改后)的表的别名
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
劳双韶旭
2019-05-22 · TA获得超过3702个赞
知道大有可为答主
回答量:3121
采纳率:27%
帮助的人:429万
展开全部
if
(object_id('tgr_classes_insert',
'tr')
is
not
null)
drop
trigger
tgr_classes_insert
go
create
trigger
tgr_classes_insert
on
t_user
for
insert
--插入触发
as
--定义变量
declare
@username
varchar(20),
@password
varchar(20),
@temp
int;
--在inserted表中查询已经插入记录信息
select
top
1
@username
=
username,
@password
=
userpass
from
t_user
order
by
deac;
insert
into
login
(username,userpass)values(@username,@password)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
hy1397471
推荐于2017-09-26 · 知道合伙人软件行家
hy1397471
知道合伙人软件行家
采纳数:4714 获赞数:17154
15年数据库维护及数据库应用系统开发经验,从事零售业、服务业及财务管理类系统开发与维护。

向TA提问 私信TA
展开全部
基本语法格式
create trigger tri_name
on table
for insert/update/deleted
as
SQL code

例:
create trigger tri_mc(tri_mc:自定义触发器的名称)
on table (table:触发的表名)
for insert (触发类型:insert,插入数据触发 update,更新数据触发 delete,删除数据触发)
as
declare @kssj datetime (定义一个变量,做中间处理)
declare @sqbh char(40)
select @kssj = kssj,@sqbh = sqbh from inserted
(插入数据时,插入的数据在表 inserted
更新数据时,更新后的数据在表 inserted 更新前的数据在表中 deleted
删除数据时,删除的数据在表 deleted
不同的操作可以,取出不同的中间数据,做处理,例子中取出插入的数据)
update table2 set isks = 1,kksj = @kssj where sqbh = @sqbh
(根据中间处理做相应操作,例子的处理为,将插入的值同步更新到另一个表)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式