数据库SQL触发器实例讲解.docxVIP

  1. 1、本文档共24页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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

文档评论(0)

laugh + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档