关系数据库与SQL Server 2005 教学课件 作者 龚小勇 第28讲 触发器(实验).pptVIP

关系数据库与SQL Server 2005 教学课件 作者 龚小勇 第28讲 触发器(实验).ppt

  1. 1、本文档共10页,可阅读全部内容。
  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文档。上传文档
查看更多
第9章 存储过程和触发器 ——触发器的使用(实验) 主讲人:段利文 第9章 存储过程和触发器 ——触发器的使用 实验项目 动手实验1:insert触发器的创建和激活 动手实验2: delete触发器的创建和激活 动手实验3: update触发器的创建和激活 动手实验4:触发器的删除 动手实验1: insert触发器的创建和激活 任务1:在xscj库的xs_kc表上创建1个名为tr_insert_cj的触发器,当向xs_kc表进行插入操作时激发该触发器,并给出提示信息“有新成绩插入到xs_kc表中!”。 create trigger tr_insert_cj on xs_kc after insert as print ‘有新成绩信息插入到xs_kc表! ’ go insert into xs_kc values( 020105, 101, 87, null ) 请思考:如果再执行一次上面的插入语句,该触发器能否被触发?为什么? 任务2:验证教材P183例7-10 。 动手实验2: delete触发器的创建和激活 任务:在xscj库的xsqk表上创建1个名为tr_delete_xsqk的触发器,当要删除指定学号的行时,激发该触发器,撤消删除操作,并给出提示信息“不能删除xsqk表中的信息!”。 create trigger tr_delete_xsqk on xsqk after delete as rollback transaction print ‘不能删除xsqk表中的信息!’ go 请思考:分别执行以下两条删除语句, 哪条语句能激活该delete触发器?不能激活触发器的语句违反了什么约束? delete xsqk where 学号= ‘020101’ delete xsqk where 学号= ‘020103’ 动手实验3: update触发器的创建和激活 任务1:验证教材P184例7-11。 请回答: 该题是如何实现级联修改的? 参考了哪些表? 为什么能从临时表中提取更新前后的学号值? 能否不要“where delete.姓名=inserted.姓名”子句? 动手实验3: update触发器的创建和激活 create trigger tr_update_xsqk1 on xsqk after update as declare @原学号 char(6),@新学号 char(6) select @原学号=deleted.学号, @新学号= inserted.学号 from deleted, inserted print ‘准备级联更新xs_kc表中的学号信息….’ update xs_kc set 学号=@新学号 where 学号=@原学号 print ‘已经级联更新了xs_kc表中原学号为’+ @原学号 +‘的学号,其新学号为:’ +@新学号 动手实验3: update触发器的创建和激活 任务2:验证教材P185例7-12。在xs_kc表上创建名为tr_update_xs_kc的触发器,用于检测该表的“成绩”列是否被更新,当有更新时,显示其学号、课程号、原成绩和新成绩。 create trigger t_update_xs_kc on xs_kc after update as if update(成绩) select inserted.学号, inserted.课程号, deleted.成绩 as 原成绩, inserted.成绩 as 新成绩 from deleted, inserted where deleted.学号=inserted.学号 go update xs_kc set 成绩=成绩-5 where 课程号= 102 动手实验4: 删除触发器 任务:删除xscj库中的所有触发器。 drop trigger tr_insert_cj, tr_insert_xsqk 本课小结 触发器的含义、作用 触发器的类型: 后触发器、替代触发器 触发器执行期间的临时表 inserted 表 、deleted表 创建触发器 insert触发器、delete触发器、

文档评论(0)

开心农场 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档