- 1、本文档共51页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第6章 触发(上海电力学院)
第六章 触发器 学习重点: ?掌握触发器的创建 ?掌握触发器的删除、修改、执行方法 ?掌握管理和维护触发器的方法 一、内容回顾 ?概述 三、创建触发器语法: CREATE TRIGGER trigger_name ON { table | view } [ WITH ENCRYPTION ] {????{ { FOR | AFTER | INSTEAD OF } { [ INSERT ] [ , ] [ UPDATE ] }????????[ WITH APPEND ]????????[ NOT FOR REPLICATION ]????????AS????????[ { IF UPDATE ( column )????????????[ { AND | OR } UPDATE ( column ) ]????????????????[ ...n ]????????| IF ( COLUMNS_UPDATED ( ) { bitwise_operator } updated_bitmask )????????????????{ comparison_operator } column_bitmask [ ...n ]????????} ] ????????sql_statement [ ...n ] ????} } 方法二:使用触发器,前提是SC表没有定义和student表相关的外键 create trigger stu_del on student for delete as Begin Begin transaction declare @stu_sno char(8) select @stu_sno=deleted.sno from deleted delete from sc where sc.sno=@stu_sno Commit tran End 实例3: insert into sc values(‘2006002’,’c001’,80) ,如何修改他的已修学分? Create triger update_credit On student After insert As Begin declare @c_no char(4), @s_no char(8),@cdit int select @c_no=cno,@s_no=sno from inserted select @cdit=credit from course where cno=@c_no update student set credit =credit+@cdit where sno=@s_no end Employee表与jobs表的关系图如下: else begin update student set sumgrade=(select sum(grade) from sc where sc.sno=student.sno) where sno in (select sno from deleted) end commit transaction 另一种方法: create trigger sc_change on sc for update,insert,delete as begin transaction if exists(select * from deleted) begin update student set sumgrade=(select sum(grade) from sc where sc.sno=student.sno) where sno in (select sno from deleted) end else begin update student set sumgrade=(select sum(grade) from sc where sc.sno=student.sno) where sno in (select sno from inserted) end commit transaction 实例7、使用延迟名称解析 USE pubs CREATE TRIGGER trig1 on authors FOR INSERT, UPDATE, DELETE AS SELECT a.au_lname, a.au_fname
您可能关注的文档
- 第5章 物信息系统实施.ppt
- 第5章 程序设计方法9.ppt
- 第5章 基LPC2292 ARM应用系统设计.ppt
- 第5章 第节 元素周期律元素周期表.ppt
- 第5章 财总预算会计.ppt
- 第5章 第节 元素周期律.ppt
- 第5章 第讲 原子结构.ppt
- 第5章 资编辑工具Resource Hacker.ppt
- 第5章 能力需求计划8.ppt
- 第5章 下载与上传Internet资源.ppt
- 2025至2030手机电池行业发展趋势分析与未来投资战略咨询研究报告.docx
- 2025至2030酶工程制品行业产业运行态势及投资规划深度研究报告.docx
- 2025至2030金融行业产业运行态势及投资规划深度研究报告.docx
- 2025至2030中国计算机教育行业发展分析及发展趋势分析与未来投资战略咨询研究报告.docx
- 2025至2030中国静脉仪器行业发展趋势分析与未来投资战略咨询研究报告.docx
- 2025至2030汽车子框架行业发展趋势分析与未来投资战略咨询研究报告.docx
- 2025至2030眼睛测试设备行业产业运行态势及投资规划深度研究报告.docx
- 2025至2030全球及中国游戏开发软件行业发展趋势分析与未来投资战略咨询研究报告.docx
- 安全监察人员考试彩蛋押题附完整答案详解【全国通用】.docx
- 2024年安全监察人员题库含完整答案详解【典优】.docx
文档评论(0)