sql触发器语法选读.pptxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第七章 ——触发器 本节要点 A 认识触发器 B 触发器的分类 C 触发器的创建 D 使用触发器 E 触发器练习的巩固 典型的应用就是银行的取款机系统 帐户信息表bank 交易信息表transInfo 张三取钱200 问题: 没有自动修改张三的余额 最优的解决方案就是采用触发器: 它是一种特殊的存储过程 也具备事务的功能 它能在多表之间执行特殊的业务规则 张三开户1000元,李四开户1元 为什么需要触发器 一、认识触发器 1、触发器的概述 定义:触发器是在对指定表插入(insert)、更新(update)或删除(delete)操作时所自动执行的存储过程。 作用:实现由主键和外键所不能保证的复杂的参照完整性和数据的一致性。 触发器是一种高级约束,可以定义比用check 约束更为复杂的约束 可执行复杂的SQL语句(if/while/case) 可引用其它表中的列 所有数据值均正确的状态 一、认识触发器 相似:触发器与存储过程相似,触发器也是SQL语句集。 区别:触发器不能用execute语句调用,而是在用户执行Transact-SQL语句自动执行。 2、触发器与存储过程的区别 运行方式区别: 存储过程 用户 应用程序或触发器 调用并执行 触发器 特定事件,自动执行 二、触发器的分类 1、DDL触发器 定义:当服务器或者数据库中发生数据定义语言(DDL)时触发器将被调用。 DDL数据定义语言:创建,修改或删除数据库中各种对象,包括表,视图,索引等。 以下操作可以使用DDL触发器: 1、要防止对数据库架构进行某些修改 3、要记录数据架构中的更改或者事件。 2、希望数据库中发生某种情况以响应数据库架构中的修改 二、触发器的分类 1、DML触发器 定义:当数据库服务器中发生数据操作语言(DML)事件时要执行的操作。 DML数据定义语言:对已存在数据库表进行元组插入,删除,修改。 2、DML触发器的用途 ( 1 ) DML触发器可通过数据库中相关表实现级联修改,通过级联引用完整性约束可以更有效的更改。 ( 2 )DML触发器可以防止恶意或者错误insert,update,以及delete操作,并强制执行比check约束 定义的限制更为复杂的其他限制。 ( 3 )DML触发器可以评估数据修改前后表的状态,并根据该差异采取措施。 ( 4 )一个表的多个同类DML触发器,允许采取多个不同的操作来响应同一个修改语句。 二、触发器的分类 触发器触发时 创建了DELETED表和INSERED表 只读,不允许修改;触发器执行完成后,自动删除 1、delete表 delete表存放由执行delete或者update语句而要从表中删除所有行,在执行delete或update被删除的行从触发触发器表中移动到delete表中。 2、insert表 insert表存放由执行insert或者update语句而要向表中插入的所有的行,在执行insert或update新的行同时添加到触发器的表和insert表中,insert表的内容是触发触发器的表新行的副本。 二、触发器的分类 修改操作 inserted表 deleted表 增加(INSERT)记录 存放新增的记录 ------ 删除(DELETE)记录 ----- 存放被删除的记录 修改(UPDATE)记录 存放更新后的记录 存放更新前的记录 inserted表和deleted表存放的信息 三、触发器创建语法 create trigger 触发器名称 on 表名 / 视图名 for / after /insted of --触发的时机 delete/insert/update --触发器的类型 as sql语句 end 例:在student数据库的‘学员信息表’表中 创建一个stuinfo_delete触发器 四、DML触发器 1、insert触发器 insert触发器对目标表执行insert语句时,就会调用触发器。 例如我们添加一个年龄列,这个触发器的名称为stuinfo_insert 插入一个新的学员信息,以验证触发器是否 执行 insert into stuinfo value (0002, mike, 男, 1993-01-25, null) select *from stuinfo 插入记录行 触发insert触发器。向inserted表中插入新行的副

文档评论(0)

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

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

1亿VIP精品文档

相关文档