宏晶第二阶段sqlserver2005第七课_第1页
宏晶第二阶段sqlserver2005第七课_第2页
宏晶第二阶段sqlserver2005第七课_第3页
宏晶第二阶段sqlserver2005第七课_第4页
宏晶第二阶段sqlserver2005第七课_第5页
免费预览已结束,剩余30页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、SQLServer2005 第七课本章目标了解为什么需要触发器理解触发器的工作原理掌握如何使用inserted表和deleted表掌握如何创建:INSERT触发器UPDATE触发器DELETE触发器为什么需要触发器(TRIGGER)呢?典型的应用就是银行的取款机系统 为什么需要触发器演示: 为什么需要触发器.sql帐户信息表bank 交易信息表transInfo 张三取钱200 问题:没有自动修改张三的余额最优的解决方案就是采用触发器:它是一种特殊的存储过程 也具备事务的功能 它能在多表之间执行特殊的业务规则 张三开户1000元,李四开户1元 什么是触发器 3-1张三李四王五赵二王三宋二刘五插

2、入删除触发器触发赵二退休 赵二员工表退休员工表触发器是在对表进行插入、更新或删除操作时自动执行的存储过程触发器通常用于强制业务规则触发器是一种高级约束,可以定义比用CHECK 约束更为复杂的约束 可执行复杂的SQL语句(if/while/case)可引用其它表中的列 自动触发执行不能直接调用是一个事务(可回滚)什么是触发器 3-2触发器类型SQL Server2005 包括两大类触发器: (1)DML触发器 在数据库中发生数据操作语言 (DML) 事件时将启用。DML 事件包括在指定表或视图中修改数据的 INSERT 语句、UPDATE 语句或 DELETE 语句。DML 触发器可以查询其他表

3、,还可以包含复杂的 Transact-SQL 语句。DML触发器将触发器本身和触发事件的语句作为可以在触发器内回滚的单个事务对待。也就是说,当在执行触发器操作过程中,如果检测到错误发生,则整个触发事件语句和触发器操作的事务自动回滚。 (2)DDL触发器 是SQL Server 2005 的新增功能。当服务器或数据库中发生数据定义语言 (DDL) 事件时将调用这些触发器。 DML触发器的基本类型按照触发器事件类型的不同,可以将DML触发器分成2种基本类型:after触发器Instead of触发器DML触发器的创建和应用 当数据库中发生数据操作语言 (DML) 事件时将调用 DML 触发器。从而

4、确保对数据的处理必须符合由这些SQL语句所定义的规则。 DML 触发器的主要优点如下:(1)DML 触发器可通过数据库中的相关表实现级联更改。(2)DML 触发器可以防止恶意或错误的 INSERT、UPDATE 以及 DELETE 操作,并强制执行比 CHECK 约束定义的限制更为复杂的其他限制。与 CHECK 约束不同,DML 触发器可以引用其他表中的列。(3)DML 触发器可以评估数据修改前后表的状态,并根据该差异采取措施。 DML触发器创建 当创建一个触发器时必须指定如下选项: (1)名称;(2)在其上定义触发器的表或视图;(3)触发器将何时激发;(4)激活触发器的数据修改语句,有效选项

5、为 INSERT、UPDATE 或 DELETE,多个数据修改语句可激活同一个触发器;(5)执行触发操作的编程语句。 DML触发器创建语法格式:create trigger trigger_name on table_name|view_name WITH ENCRYPTION for|after|instead of delete, insert, updateas T-SQL语句DML触发器创建after:是指在对表的相关操作正常操作后,触发器被触发。如果仅指定for关键字,则after是默认设置。Instead of:指定执行触发器而不执行触发语句,从而替代触发语句的操作。可以为表或视图

6、中的每个insert、update或delete语句定义一个instead of触发器。delete, insert, update:是指在表或视图上执行哪些数据修改语句时激活触发器的关键字。允许以任意顺序组合使用多个关键字,用逗号分割。 inserted 和deleted 表触发器触发时:系统自动在内存中创建deleted表或inserted表只读,不允许修改;触发器执行完成后,自动删除inserted 表 临时保存了插入或更新后的记录行 可以从inserted表中检查插入的数据是否满足业务需求 如果不满足,则向用户报告错误消息,并回滚插入操作deleted 表临时保存了删除或更新前的记录行

7、 可以从deleted表中检查被删除的数据是否满足业务需求 如果不满足,则向用户报告错误消息,并回滚删除操作 inserted 和deleted 表操作inserted表deleted表增加(INSERT)记录存放新增的记录-删除(DELETE)记录-存放被删除的记录修改(UPDATE)记录存放更新后的记录存放更新前的记录inserted表和deleted表存放的信息INSERT触发器工作原理transInfocardIDtransType transMoney1001 00021001 0002存入 300存入 500insertedcardIDtransType transMoney100

8、1 0001 支取 200transInfocardIDtransType transMoney1001 00021001 0002存入 300存入 5001001 0001支取 200插入记录行触发insert触发器。向inserted表中插入新行的副本触发器检查inserted表中插入的新行数据,确定是否需要执行或回滚其他操作INSERT 触发器示例 3-1 问题:解决上述的银行取款问题:当向交易信息表(transInfo)中插入一条交易信息时,我们应自动更新对应帐户的余额。 分析:在交易信息表上创建INSERT触发器 从inserted临时表中获取插入的数据行根据交易类型(transTy

9、pe)字段的值是存入/支取,增加/减少对应帐户的余额。 INSERT 触发器示例create trigger tr_transinfoon transinfofor insertasdeclare type char(4),transMoney money,cardId char(10),balance moneyselect type=transType,transMoney=transMoney,cardId=cardIdfrom insertedif(type=存款)beginupdate bank set currentMoney=currentMoney+transMoney whe

10、re cardId=cardIdprint 存款成功!交易额:+ convert(char,transMoney)endelsebeginupdate bank set currentMoney=currentMoney+transMoney where cardId=cardIdprint 取款成功!交易额:+ convert(char,transMoney)endselect balance = currentMoney from bank where cardId =cardIdprint 卡号:+cardId +余额: + convert(char,balance)根据交易类型,减少或

11、增加对应卡号的余额 从inserted表中获取交易类型、交易金额等INSERT 触发器示例示例:向交易表中插入一条交易信息如下:insert transinfo values(1001,存款,100,getdate()DELETE触发器transInfocardIDtransType transMoney1001 00021001 0002存入 300存入 5001001 0001支取 200transInfocardIDtransType transMoney1001 00021001 0002存入 300存入 500deletedcardIDtransType transMoney1001

12、 0001支取 200删除记录行触发delete触发器向deleted表中插入被删除的副本触发器检查deleted表中被删除的数据,决定是否需要回滚或执行其他操作DELETE触发器的工作原理:问题:当删除交易信息表时,要求自动备份被删除的数据到表backupTable中 。分析:在交易信息表上创建DELETE触发器 被删除的数据可以从deleted表中获取DELETE触发器示例-关键代码-CREATE TRIGGER trig_delete_transInfo ON transInfo FOR DELETE AS print 开始备份数据,请稍后. IF NOT EXISTS(SELECT *

13、 FROM sysobjects WHERE name=backupTable) SELECT * INTO backupTable FROM deleted ELSE INSERT INTO backupTable SELECT * FROM deleted print 备份数据成功,备份表中的数据为: SELECT * FROM backupTable GO 从deleted表中获取被删除的交易记录DELETE触发器示例DELETE触发器示例UPDATE触发器Deleted(更新前的数据)customerNamecardID currentMoney李四1000 0002 1bankcus

14、tomerName cardID currentMoney张三 10010001 1000 李四10000002 1删除记录行向deleted表中插入被删除的副本检查deleted和inserted表中的数据,确定是否需要回滚或执行其他操作UPDATE触发器的工作原理:李四 10000002 20001向inserted表中插入被添加的副本Inserted(更新后的数据)customerNamecardID currentMoney李四1000 0002 20001插入记录行问题:跟踪用户的交易,交易金额超过20000元,则取消交易,并给出错误提示。 分析:在bank表上创建UPDATE触发器

15、 修改前的数据可以从deleted表中获取修改后的数据可以从inserted表中获取UPDATE触发器示例-关键代码-CREATE TRIGGER trig_update_bank ON bank FOR UPDATE AS DECLARE beforeMoney MONEY,afterMoney MONEY SELECT beforeMoney=currentMoney FROM deleted SELECT afterMoney=currentMoney FROM inserted IF ABS(afterMoney-beforeMoney)20000 BEGIN print 交易金额:+

16、convert(varchar(8), ABS(afterMoney-beforeMoney) RAISERROR (每笔交易不能超过2万元,交易失败,16,1) ROLLBACK TRANSACTION ENDGO 从deleted表中获取交易前的余额,从inserted表中获取交易后的余额UPDATE触发器交易金额是否2万回滚事务,撤销交易UPDATE触发器示例:向交易表中插入一条交易信息如下:insert transinfo values(1001,存款,100000,getdate()insert transInfo values(1001,取款,20000,getdate()列级触发

17、器列级触发器就是对表中的某列进行添加或修改时所执行的触发器。 建立列级触发器与建立触发器的语法是相同的,只是在创建时使用update(column)或columns_updated()函数。 语法:CREATE TRIGGER trigger_nameON table | view FOR | AFTER | INSTEAD OF INSERT , UPDATE AS IF UPDATE ( column ) AND | OR UPDATE ( column ) .n | IF ( COLUMNS_UPDATED ( ) bitwise_operator updated_bitmask ) c

18、omparison_operator column_bitmask .n sql_statement .n 列级触发器列级触发器问题:交易日期一般由系统自动产生,默认为当前日期。为了安全起见,一般禁止修改,以防舞弊。 分析:UPDATE(列名)函数可以检测是否修改了某列 update (column):测试在指定列上进行的INSERT或UPDATE操作,不能用于DELETE操作,可以指定多列。因为在ON子句中指定了表名,所以在 IF UPDATE子句中的列名前不要包含表名。若要测试在多个列上进行的INSERT或UPDATE操作,可在第一个操作后指定单独的 update(column)子句。在I

19、NSERT操作中IF UPDATE将返回TRUE值,因为这些列插入了显式值或隐性(NULL)值。 -关键代码-CREATE TRIGGER trig_update_transInfo ON transInfo FOR UPDATE AS IF UPDATE(transDate) BEGIN print 交易失败. RAISERROR (安全警告:交易日期不能修改, 由系统自动产生,16,1) ROLLBACK TRANSACTION ENDGO 检查是否修改了交易日期列transDate回滚事务,撤销交易列级触发器列级触发器columns_updated():返回 varbinary 位模式,

20、它指示表或视图中插入或更新了哪些列。 columns_updated可用于 INSERT 或 UPDATE 触发器主体内部的任意位置,以测试该触发器是否应执行某些操作。columns_updated针对多列执行的 UPDATE 或 INSERT 操作的进行测试 可以理解为columns_updated函数返回一个整数,整数的对应的二进制位表示哪一列是否有更新。上面表示第2列和第4列进行了更新,函数返回的整数值为1000001010-测试第二列和第四列是否被同时更新if columns_updated()&10 =10beginselect sno,sname,cnointo newstudentfrom deleted -inserted updated分成两部分。deleted 和 insertedend列级触发器Instead of触发器实例:在视图view_student_course上创建一个instead of触发器,当向视图中插入数据时触发该触发器,该触发器先判断course表是否已经存在该课程,如果不存在则在course表中插入该课程。然后再将学生信息插入到student表中。Instead of触发器create

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论