SQL Server 2005实用教程 教学课件 蒋文沛2 第9章 触发器.pptVIP

SQL Server 2005实用教程 教学课件 蒋文沛2 第9章 触发器.ppt

  1. 1、本文档共20页,可阅读全部内容。
  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文档。上传文档
查看更多
学习目标 1、了解触发器与一般存储过程的区别 2、理解触发器的概念以及分类 3、掌握创建触发器的两种方法以及触发器的使用、修改和删除 触发器 触发器是一种特殊的存储过程,在语言事件发生时,所设置的触发器就会自动被执行,以进行维护数据完整性,或其他一些特殊的任务。 与上一章介绍的一般意义上的存储过程不同,触发器可以说是当发生DML或DDL语言事件时自动执行的存储过程。不能直接被调用,也不能传递或接受参数。 DML触发器 DML触发器是一种与表紧密关联的特殊的存储过程,当数据库中发生数据操作语言(DML)事件时将调用DML触发器。 (1)DML触发器 在建立DML触发器时,要指定触发操作:insert、update或delete。至少要指定一种操作,也可以同时指定多种。在同一个表中可以创建多个after触发器,但在表或视图上,每个insert、update或delete语句最多可以定义一个instead of触发器。 (2)DDL触发器 DDL触发器是响应create、alter、drop、grant、deny、revoke 和 update statistics 等语句而触发的。 触发器的功能 1、DML触发器 DML触发器有助于在表或视图中修改数据时强制业务规则,扩展数据完整性,它具有以下功能: (1)级联修改数据库中相关的表; (2)实现比check约束更为复杂的约束操作; (3)拒绝或回滚违反引用完整性的约束操作; (4)比较表修改前后数据之间的差别,并根据差别采取相应的操作。 2、DDL触发器 DDL触发器用于执行管理任务,并强制影响数据库的业务规则。它具有以下功能: (1)防止对数据库架构进行某些更改; (2)使得数据库中发生某种情况以响应数据库架构中的更改; (3)记录数据库架构中的更改或事件。 创建触发器 使用SSMS创建DML触发器 使用Transact-SQL创建DML触发器 使用Transact-SQL创建DDL触发器 create trigger语句的语法格式 DML触发器创建的表 【例9.2】 创建一个AFTER INSERT触发器,当在Sales数据库的employees表中插入一条新员工记录时,如果不是“采购部”、“财务部”、“销售部”或“库存部”的员工,则撤销该插入操作,并返回出错消息。 【例9.3】 在Sales数据库的employees表和Sell表之间具有逻辑上的主外键关系,要求当删除或更新单个员工记录的时候,要激发触发器tri_Delete,在Sell表中也删除或更新相对应的记录行。 创建DDL触发器的语法格式如下 数据库作用域的事件如下所述: 【例9.4】在Sales数据库中,创建一个DDL触发器,以防止视图的删除。 【例9.5】创建一个DDL触发器,以保护当前服务器中的所有数据库不能被删除。 修改触发器 使用SSMS查看和修改DML触发器 使用Transact-SQL查看和修改DML触发器 查看DML触发器信息 EXEC sp_helptrigger 表名|视图名 [,触发器操作类型] 查看触发器的定义文本 EXEC sp_helptext 触发器名称 修改DML触发器 禁用或启用DML触发器 通过SSMS禁用或启用触发器 使用T-SQL语句禁用或启用DML触发器 修改DDL触发器 删除触发器 通过SSMS删除触发器 使用Transact-SQL删除触发器 * 允许 不允许 在inserted表和deleted表引用text、ntext和image类型的数据 可以指定第一个和最后一个触发器执行动作 在创建inserted表和deleted表触发时 声明引用动作之后 没有限制 允许每个动作有 多个触发器 表 after 触发器 执行顺序 执行时机 级联引用 每个表或视图 可用的数量 适用对象 功 能 不适用 在inserted表和deleted表创建之后 在约束处理之前,代替了触发动作 在作为级联引用完整性约束目标的表上限制应用 每个动作(update、delete和insert)一个触发器 表和视图 instead of触发器 create trigger [所有者.]触发器名称 on {[所有者.]表名|视图} [with encryption] {for|after|instead of} { [insert ][,][update] [,] [delete] } [not for replication] as if update(列名) [and | or update(列名)] […n] sql语句 […n] 否 是 是 创建inserted表 delete update inser

您可能关注的文档

文档评论(0)

118压缩包课件库 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档