触发器学习笔记(一)

触发器

在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。

常见的触发器有三种:

分别应用于Insert , Update , Delete 事件。 

两个临时的表:

Deleted , Inserted 。

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

一个数据库系统中有两个虚拟表用于存储在表中记录改动的信息,分别是: 

    虚拟表Inserted  虚拟表Deleted
新增时 存放新增的记录 不存储记录
修改时 存放用来更新的新记录  存放更新前的记录
删除时 不存储记录  存放被删除的记录

 


数据库脚本下载
    实例脚本下载

1.每增加一条图书记录,学生的借书次数+1
--1.每增加一条图书记录,学生的借书次数+1
IF EXISTS (SELECT * FROM SYS.OBJECTS WHERE NAME='TRUUPSTUDENT')--如果存在触发器TRUUPSTUDENT
DROP TRIGGER TRUUPSTUDENT --则删除
GO
CREATE TRIGGER TRUUPSTUDENT
ON BORROWRECORD --在BORROWRECORD表中创建触发器
FOR INSERT --为INSERT事件触发
AS --事件触发后所要做的事情
DECLARE @STUDENTID INT;
SELECT @STUDENTID=STUDENTID FROM INSERTED;
UPDATE STUDENT SET BOOKNUM=BOOKNUM+1 WHERE STUDENTID=@STUDENTID;
--测试
INSERT INTO BORROWRECORD (STUDENTID, BORROWDATE, RETURNDATE)
VALUES (1,GETDATE(),NULL)
SELECT * FROM STUDENT
SELECT * FROM BORROWRECORD
2.如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借书记录表的学号); 
--2.如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借书记录表的学号); 
IF EXISTS (SELECT * FROM SYS.OBJECTS WHERE NAME='TRUSTUDENT')--如果存在触发器TRUSTUDENT
DROP TRIGGER TRUSTUDENT --则删除
GO
CREATE TRIGGER TRUSTUDENT
ON STUDENT --在STUDENT表中创建触发器
FOR UPDATE --为什么事件触发
AS --事件触发后所要做的事情
IF UPDATE(STUDENTID)
BEGIN
UPDATE BORROWRECORD
SET STUDENTID=I.STUDENTID
FROM BORROWRECORD BR , DELETED D ,INSERTED I --DELETED和INSERTED临时表
WHERE BR.STUDENTID=D.STUDENTID
END
GO
--测试
UPDATE STUDENT SET STUDENTID=5 WHERE STUDENTNAME='马六'
SELECT * FROM STUDENT
SELECT * FROM BORROWRECORD

3.每增加一条图书记录,学生的借书次数+1

--3.如果该学生已经毕业,我希望删除他的学号的同时,也删除它的借书记录。
IF EXISTS (SELECT * FROM SYS.OBJECTS WHERE NAME='TRDSTUDENT')--如果存在触发器TRDSTUDENT
DROP TRIGGER TRDSTUDENT --则删除
GO
CREATE TRIGGER TRDSTUDENT
ON STUDENT --在STUDENT表中创建触发器
instead of delete --为什么事件触发
AS --事件触发后所要做的事情
DECLARE @STUDENTID INT;
SELECT @STUDENTID=STUDENTID FROM DELETED;
print @STUDENTID
DELETE STUDENT WHERE STUDENTID=@STUDENTID;

--测试
DELETE STUDENT where STUDENTNAME='马六'
SELECT * FROM STUDENT
SELECT * FROM BORROWRECORD

数据库脚本下载 实例脚本下载

资料来源:http://www.cnblogs.com/xianqingzh/archive/2009/04/30/1447143.html



posted @ 2012-02-25 14:07  kumat  阅读(1742)  评论(3编辑  收藏  举报