- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
- SQL Server 2005开发与管理 高职计算机应用技术 张淑梅 宋维堂 第7章.ppt
- SQL Server 2005开发与管理 高职计算机应用技术 张淑梅 宋维堂 第8章.ppt
- SQL Server 2005开发与管理 高职计算机应用技术 张淑梅 宋维堂 第9章.ppt
- SQL Server 2005开发与管理 高职计算机应用技术 张淑梅 宋维堂 第10章.ppt
- SQL Server 2005开发与管理 高职计算机应用技术 张淑梅 宋维堂 第11章.ppt
- SQL Server 2005开发与管理 高职计算机应用技术 张淑梅 宋维堂 第12章.ppt
- SQL Server 2005开发与管理 高职计算机应用技术 张淑梅 宋维堂 教案及课程标准 课程标准.doc
- SQL Server 2005开发与管理 高职计算机应用技术 张淑梅 宋维堂 习题与答案 教学模块4.doc
- SQL Server 2005开发与管理 高职计算机应用技术 张淑梅 宋维堂 习题与答案 教学模块12答案.doc
- SQL Server 2005实用教程 教学课件 蒋文沛1 第1章 SQL Server 2005的安装和配置.ppt
- 小学科学:ESP8266智能插座电路原理与动手实践研究教学研究课题报告.docx
- 《金融开放浪潮下我国多层次监管体系构建与创新研究》教学研究课题报告.docx
- 区域教育质量监测中人工智能应用的数据质量分析与优化策略教学研究课题报告.docx
- 《金融科技监管中的数据治理与合规性要求》教学研究课题报告.docx
- 《3D打印技术在航空航天领域中的多材料制造与复合材料应用》教学研究课题报告.docx
- 《绿色金融发展中的政府职能与市场机制研究》教学研究课题报告.docx
- 《植物工厂多层立体栽培光环境调控技术对植物生长发育节律的调控机制探讨》教学研究课题报告.docx
- 销售团队年度业绩总结.docx
- 银行风险管理与金融危机防范.docx
- 银行网络攻击预警与快速响应机制.docx
最近下载
- 悬挑脚手架、落地脚手架安全专项施工方案.doc VIP
- 分级护理制度精编PPT课件.pptx VIP
- 梁德清体育活动等级量表(PARS-3)及评定标准.doc VIP
- 建筑施工技术(千年土木 小筑拾遗)知到课后答案智慧树章节测试答案2025年春潍坊工程职业学院.docx VIP
- ABB.ACS580替换550指南了解.pdf VIP
- 2025年公需课《人工智能赋能制造业高质量发展》试题及答案.doc VIP
- 建筑施工技术(千年土木 小筑拾遗)智慧树知到期末考试答案章节答案2024年潍坊工程职业学院.docx VIP
- 2023兖矿能源定向委培考试.pdf
- 潮汕工夫茶调研报告.docx VIP
- 生活中的物理问题“生活中的物理”探究.pptx VIP
文档评论(0)