




已阅读5页,还剩31页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
触发器触发器类似于过程、函数,因为它们都是拥有说明部分、语句执行部分和异常处理部分的有名的PL/SQL块。与包类似,触发器必须存储在数据库中,并且不能被块进行本地化说明。但是,对于过程而言,可以从另一个块中通过过程调用显式地执行一个过程,同时在调用时可以传递参数。对于触发器而言,当触发事件发生时就会显式地执行该触发器,并且触发器不接受参数。,触发事件是在数据库表上执行的DML(INSERT、UPDATE、DELETE)操作。使用触发器,可以做许多事情,包括:维护不可能在表创建时通过说明性约束进行的复杂的完整性约束限制。通过记录所进行的修改以及谁进行了修改来审计表中的信息。当表被修改的时候,自动给需要执行操作的程序发信号。,1触发器概念及组成,制作一个数据库触发器,目的是在某个表上执行特定的数据维护操作时,隐含地执行一个PLSQL块。,例子:制作一个数据库触发器。记录下那些超过其工种工资范围的工资值(但不禁止这种操作)CREATETRIGGERcheck_salBEFOREINSERTORUPDATEOFsal,jobONempFOREACHROWWHEN(new.jobPRESIDENT)DECLAERv_minsalsal_guide.minsalTYPE;v_maxsalsal_guide.maxsalTYPE;e_sal_out_of_rangeEXCEPTION;,BEGINSELECTminsal,maxsalINTOv_minsal,v_maxsalFROMsal_guideWHEREjob:new.job;IF:new.salv_minsalOR:new:salv_maxsalTHENRAISEe_sal_out_of_range;ENDIF;EXCEPTIONWHENe_sal_out_of_rangeTHENINSERTINTOaudit_message(line_nr,line)VALUES(l,Salary|TO_CHAR(:new.sal)|isoutofrangeforemployee|TO_CHAR(:new.empno);END;,关联触发器把一个数据库触发器的动作与另一个触发器联系起来,使之触发这另一个触发器。,例子制作相关联的触发器。在一个全局变量中统计审计信息的总数,注释:参数MAXOPENCURSORS限制在一个数据库中可用的关联触发器的个数,其缺省值为32。,写触发器的源代码之前,先确定好其触发时间、触发事件及触发器的类型。内容描述可能值触发时间与触发事件的时间次序BEFOREAFTER触发事件触发触发器的数据操作INSERT事件类型UPDATEDELETE触发器类型触发器体被执行的次数StatementROW触发器体该触发器将要执行的动作完整的PLSQL块,行级触发器与语句级触发器的区别根据进行一个操作时触发器的触发次数,来决定是创建一个语句级触发器,还是创建一个行级触发器。注意当某操作只影响到表中的一行数据时,语句级触发器与行级触发器的效果相同。,例子:下面的语句对语句级触发器和行级触发器效果一样,当触发事件影响数据库的多行时,语句级触发器只触发一次,而行级触发器则每一行被触发一次。,例子-下列语句的行级触发器与语句级触发器效果不同,2创建触发器开发触发器的步骤用系统编辑器或字处理软件写一个含有CREATETRIGGER语句的脚本文件。在写CREATETRIGGER语句时,充分考虑运行时出错的处理。在SQL*Plus或SVRMGR中运行脚本文件,将触发器的源代码编译成编译代码p_code,并把源代码存储到数据库中。编译代码p_code不存储在数据库中。调试编译错误。在ORACLE环境中测试开发的触发器(用INSERT、UPDATE、DELETE语句对表进行操作)。在运行期间调试触发器的逻辑错误。,语句级触发器用CREATETRIGGBR语句创建一个语句级触发器,该触发器在一个数据操作语句发生时只触发一次。语法创建一个语句级触发器CREATEORREPLACETRIGGERtrigger_nameBEFORE|AFTERevent1ORevent2.ONtable_namePL/SQLblock,其中:triggername触发器名timing指明触发事件触发的时间顺序:BEFOREAFTERevent指明触发事件的数据操纵类型INSERTUPDATEDELETEtablename标明与该触发器相关联的表名plsqlblock触发器体,指明该触发器将执行的操作,例子1创建一个BEFORE型语句级触发器。限制一周内往EMP表插入数据的时间,例子:创建一个包含多个触发事件的触发器。在触发器体中使用条件语句,指明INSERTING,UPDATING及DELETING,从而把多种触发事件组成一个触发器。对前面的例子进行扩展,使其不但限制某周内插入数据的时间,还限制进行数据修改和删除的时间。,CREATETRIGGERsecure_empBEFOREDELETEORINSERTORUPDATEONempDECIAREv_dummyVARCHAR2(1);BEGINIF(TO_CHAR(sysdate,DYIN(SAT,SHN)OR(TO_NUMBER(sysdate,HH24)NOTBETWEEN8AND18)THENIFDELETINGTHENRAISE_APPLICATION_ERROR(一20502,YoumayonlydeletefromEMPduringnormalhours.);ELSIFINSERTINGTHENRAISE_APPLICATION_ERROR(一20500,YoumayonlyinsertintoEMPduringmormalhours);,ELSIFUPDATING(SAL)THENRAISE_APPLICATION_ERROR(一20503,YoumayonlyupdateSALcolumnduringnormalhours);ELSERAISE_APPLICATION_ERROR(一20504,YoumayonlyupdateEMPtableduringnormalhours);ENDIF;ENDIF;END;,行级触发器通过在CREATETRIGGER语句中指定FOREACHROW子句创建一个行级触发器,使其在受到触发事件影响的每一行上都被触发。语法:创建一个行级触发器CREATEORREPLACETRIGGERtrigger_nameBEFORE|AFTERtrigger_event1ORtrigger_event2.ONtable_nameFOREACHROWWHENrestricting_conditionPL/SQLblock;其中:restrictingcondition为指定的条件,以确定触发器体是否被执行。,例子:创建一个行级触发器。记录下每个用户对数据库的表进行数据操纵的次数CREATETRIGGERaudit_empAFTERDELETEORINSERTORUPDATEONempFOREACHROWBEGINIFDELETINGTHENUPDATEaudit_tableSETdeldel+lWHEREuser_name=userANDtable_nameEMPANDcolun_nameISNULL;,ELSIFINSERTINGTHENUPDATEaudit_tableSETins=ins+lWHEREuser_name=userANDtable_name=EMPANDcolumn_nameISNULL;ELSIFUPDATING(sal)THENUPDATEaudit_tableSETupd=upd+lWHEREuser_nameuserANDtable_name=EMPANDcolumnname=SAL;,EISEUPDATEaudit_tableSETupd=upd+1WHEREuser_name=userANDtable_nameEMPANDcolumn_nameISNULL;ENDIF;END;,注释:如果一个触发器不必在触发事件前触发,请创建AFTER型触发器(不要创建BEFORE型),行级触发器的标识符在行级触发器中,在列名前加上OLD标识符标识该列变化前的值,加上NEW标识符标识变化后的值。数据操作旧值新值InsertNULL插入的值Update修改前的值修改后的值Delete删除前的值NULL,例子:在行级触发器中获取某列的新值和旧值。为EMP表中的所有数据保留一个历史档案(审计),详细的用户审计表,用WHEN子句来保证,当某些行满足一定条件时,在该行上行级触发器才被触发。,例子:在行级触发器限制其触发。自动计算销售员的奖金,注释:在WHEN子句中,标识符前不加冒号(:)在语句级触发器中不要使用WHEN子句。,3触发器的管理,管理触发器的命令与管理过程的命令相似。任务命令_创建一个新的触发器CREATETRIGGER修改一个已有的触发器CREATEORREPLACETRIGGER删除触发器DROPTRIGGER与过程不同的是,当一个触发器不再适宜被触发时,可以使其处于无效状态。,语法使一个数据库触发器无效,语法:使一个数据库触发器重新变为有效,注释:当触发器刚创建时,它被自动置为有效。为了改善性能,以及在大量装载数据时(例如使用SQL*Loader)避免进行数据的完整性校验,可以使数据库触发器暂时无效。当发生网络连接故障、磁盘损坏,数据文件脱机或表空间脱机,从而导致触发器中涉及到的实体不能再被访问时,应使触发器失效。,管理触发器的命令与管理过程的命
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年度高品质钢筋螺纹钢大宗采购供应合同
- 2025版寄售交易合同:珠宝首饰寄售合作协议
- 2025版农业贷款合同书附带借款收据
- 二零二五年度大型旅游客车租赁服务合同
- 二零二五版建筑工程钢筋材料承包合同示范文本
- 二零二五版房地产项目股东融资合同书
- 教育行业学生隐私权保护合同
- 2025房屋租赁代理合同
- 物联网技术在智能家居中的应用服务协议
- 以青春之名作文800字9篇
- 北京市朝阳区2024-2025学年高一下学期期末语文试题(含答案)
- 牙外伤护理配合课件
- 新高一家长会课件
- 腹部血管超声诊断
- 2025年公务员考试时事政治模拟题附答案详解(模拟题)
- 医学美容技术专业教学标准(高等职业教育专科)2025修订
- 党课课件含讲稿:以作风建设新成效激发干事创业新作为
- 2025数学常考压轴题上册八年级(沪科版)专题13 全等三角形模型之半角模型和边边角模型-解析版
- JG/T 396-2012外墙用非承重纤维增强水泥板
- 南通市崇川区卫生健康委员会所属事业单位招聘考试真题2024
- 《安全生产考核巡查办法》知识培训
评论
0/150
提交评论