- 1、本文档共24页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
SQL触发器实例讲解1
SQL触发器实例1
定义:何为触发器?在SQLServer里面也就是对某-个衣的-定的操作,触发某种条件,从而 执行的一段程序。触发器是一个特殊的存储过程。
常见的触发器有三种:分别应用于Insert, Update , Delete事件。
我为什么要使用触发器?比如,这么两个农:
Create Table Student( 一学生衣
StudentID int primary key, 一学号
八学生借书记录农Create Table BorrowRecord(
八学生借书记录农
BorrowRecord int identity(1,1), ??流水号
StudentID int, BorrowDate dateti me,
Return DAte Dateti me,
用到的功能有:
如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借 书记录农的学号);
如果该学生已经毕业,我希望删除他的学号的同时,也删除它的借书记录。 等等。
这时候可以用到触发器。对于1,创建?个Update触发器:
Create Trigger truStudent
On Student ??在Student农中创建触发器
for Update ??为什么事件触发
As --事件触发后所要做的事情
if Update(StudentlD)
begin
Update BorrowRecord
Set Student I D=i. Student ID
From BorrowRecord br, Deleted d ,Inserted i -Deleted 和 Inserted 临时农
Where br.StudentlD=d.StudentID
end
理解触发器里面的两个临时的衣:Deleted , Inserted。注Deleted与Inserted分别衣示
触发事件的表“旧的?条记录”和“新的?条记录寫
?个数据库系统中有两个虎拟衣用于存储在衣中记录改动的信息,分别是:
虚拟农Inserted
虚拟农Inserted
虚拟表Deleted
在农记录新增时 修改时 删除时存放新增的记录存放用来更新的新记录
在农记录新增时 修改时 删除时
存放新增的记录
存放用来更新的新记录
不存储记录
不存储记录
存放更新前的记录 存放被删除的记录
?个Update的过程可以看作为:生成新的记录到Inserted农,复制I口的记录到Deleted农, 然后删除Student记录并写入新纪录。
对于2,创建?个Delete触发器
Create trigger trdStudent
On Student
for Delete
As
Delete BorrowRecord
From BorrowRecord br, Delted d
Where br.StudentlD=d.StudentlD
从这两个例?我们可以看到了触发器的关键:A.2个临时的衣;B.触发机制。
SQL触发器实例2
建立虚拟测试环境,包含:衣[卷烟條存农],农[卷烟销售衣]。
请大家注意跟踪这两个衣的数据,体会触发器到底执行了什么业务逻辑,对数据有什么影响。 为了能更清晰的衣述触发器的作用,衣结构存在数据冗余,且不符合第三范式,这里特此说明。 */
USE Master
GO
IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPEAND NAME =卷烟库存农) DROP TABLE卷烟库存表
GO
IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPE = ,U, AND NAME =卷烟销售农) DROP TABLE卷烟销售衣
GO
-业务规则:销售金额=销售数量*销售单价业务规则。
CREATE TABLE卷烟销售衣 卷烟品牌 VARCHAR(40) PRIMARY KEY NOT NULL, 购货商 VARCHAR(40) NULL,
销售数量I NT NULL,
销售单价MONEY NULL,
销售金额MONEY NULL
)
GO
-业务规则:库存金额=丄牟存数量*库存单价业务规则。
CREATE TABLE卷烟库存农
(
卷烟品牌 VARCHAR(40) PRIMARY KEY NOT NULL,
库存数量I NT NULL,
库存单价MONEY NULL,
库存金额MONEY NULL
)
GO
-创建触发器,示例I
创建触发器[T-INSERT.卷烟库存衣],这个触发器较简单。
说明:每当[卷烟库存表]发生INSERT动作,则引发该触发器。
触发器功能:强制执行业务规则,保证插入的数据中,库存金额=库存数量*库存单价。
注意:[INSE
您可能关注的文档
- 曲与直作文曲与直作文.docx
- 全新版大学英语综合教程3单词汇总.docx
- 人教版《道德与法治》七年级下册-10.1-法律为我们护航-学案.docx
- 人教版七年级上册根据拼音写词语练习(提供语境).docx
- 人力资源管理师之培训与开发.docx
- 仁爱英语八年级下册词汇练习题.docx
- 三年级上册课后生字组词.docx
- 三年级数学下册练习脱式计算题300道题.docx
- 散文专题讲解.docx
- 森林防火措施.docx
- 公用设备工程师之(暖通空调+动力)基础知识综合提升模拟考试试卷包含答案.docx
- 2022-2023年标准员之基础知识训练试卷提供答案解析.docx
- 2022-2023年资料员之资料员专业管理实务通关训练试卷和答案.docx
- 2022-2023年一级造价师之建设工程技术与计量(水利)考前冲刺练习题附答案详解.docx
- 2023年二级建造师之二建建筑工程实务考前冲刺模拟题库包括详细解答.docx
- 2022-2023年中级银行从业资格之中级个人理财考前冲刺模拟考试试卷提供答案解析.docx
- 2022-2023年质量员之土建质量专业管理实务综合提升练习题附带答案.docx
- 执业医师资格证之临床助理医师考前冲刺训练试卷附答案.docx
- 2022-2023年试验检测师之桥梁隧道工程综合提升训练试卷.docx
- 2022-2023年证券分析师之发布证券研究报告业务综合提升模拟题库包含答案.docx
文档评论(0)