触发器学习笔记(一)
触发器
在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
作者:唐小熊
出处:http://www.cnblogs.com/IT-Bear/
关于作者:一头写代码的熊
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接
如有问题,可以通过kumat@foxmail.com 联系我,非常感谢。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构