网站大量收购独家精品文档,联系QQ:2885784924

第9讲 触发器.pptVIP

  1. 1、本文档共16页,可阅读全部内容。
  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讲 触发器 引例 触发器的作用 在指定的表中数据发生变化时被调用以响应INSERT、UPDATE或DELETE事件 强制执行业务规则 创建简单的触发器 【问题】创建一个触发器Test1,要求每当在Student表中修改数据时,向客户端显示一条“记录已修改!”的消息 SQL格式: CREATE TRIGGER trigger_name On table [WITH ENCRYPTION] {FOR|AFTER| INSTEAD OF} {[INSERT] [UPDATE] [DELETE]} AS sql_statement 在企业管理器中查看触发器信息 FOR/AFTER/INSTEAD OF的比较 【问题】将上例中触发器中的FOR UPDATE改为INSTEAD OF UPDATE,查看执行结果有何不同。 总结: 使用FOR/AFTER时,执行触发SQL语句(INSERT/UPDATE/DELETE):在触发SQL语句成功执行后,再执行触发器 使用INSTEAD OF时:执行触发器而不执行触发SQL语句 练习1 创建一个触发器,要求每当在StuCou表中插入数据时,向客户端显示一条“记录已添加!”的消息。 创建一个触发器,要求每当用户插入student表的记录时,自动显示表中所有内容 INSERTED表和DELETED表 系统为每个触发器都自动创建了INSERTED表和DELETED表 INSERTED表用于存放插入操作时的行;DELETED表用于存放删除操作时的行 这两个表的结构和被触发器作用的表的结构相同 用户不能对这两个表进行修改,但可以读取 练习2 创建一个触发器,要求每当用户插入student表的记录后,自动显示Student表中插入的记录 创建触发器 【问题】创建一个触发器SetWillNum,要求当插入、更新、删除StuCou表的选课记录时,能更新Course表中相应的报名人数。 说明:该触发器只适用于每次新增、删除一条记录的情况。 创建批量数据触发器 思考:若有批量的数据新增、插入或删除,应该如何修改上例中的触发器? 处理多条记录的触发器简单、易维护,但每次都更新Course中每条记录的报名人数,效率不高 IF UPDATE的应用 【问题】创建一个触发器Test1,要求每当student表中修改pwd列的数据时,向客户端显示一条消息“密码已更改”的消息。 特点:只有当IF UPDATE指明的列发生修改时,才触发执行触发器。 级联更新和删除: 【练习】创建触发器,当修改student表中的学号字段后,自动修改stucou表中相应的学号。(以前采用外键方式) 【练习】在student表上创建触发器del_trg,当删除表中某一个学生的记录时,能自动删除掉该学生的所有成绩记录 重命名、删除触发器 重命名触发器SQL格式: sp_rename oldname, newname 删除触发器SQL格式: DROP TRIGGER trigger_name 说明:删除触发器所在的表时,SQL Server将会自动删除与该表相关的触发器 管理触发器 禁用触发器 ALTER TABLE table_name DISABLE TRIGGER trigger_name 恢复使用触发器 ALTER TABLE table_name ENABLE TRIGGER trigger_name 显示数据库中有哪些触发器 请参考联机丛书“sysobjects系统表” 使用注意事项总结 CREATE TRIGGER要在单个批处理中执行 ON table中的表格只能是一个 在同一条CREATE TRIGGER语句中,可以为多个事件( INSERT/DELETE/UPDATE定义相同的触发器操作) 可以为每个事件(INSERT/DELETE/UPDATE)创建多个触发器 本章小结 理解:触发器的作用 创建、管理触发器的方法(重点) 如何设计触发器以简化系统设计(进一步的要求) * 思考:当学生报名选修SQLServer实用技术课程时,WillNum应自动加1,如何处理?

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档