跟我学Oracle从入门到精通培训教程——PLSQL异常和Oracle触发器.pptVIP

跟我学Oracle从入门到精通培训教程——PLSQL异常和Oracle触发器.ppt

  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文档。上传文档
查看更多
跟我学Oracle从入门到精通培训教程——PLSQL异常和Oracle触发器.ppt

2、禁用除触发器 (1)禁用触发器 为了改善性能,并且在大量移植数据时避免触发相应的触发器,应该禁用触发器,使其暂时失效。语法: Alter trigger trigger_name DISABLE; (2)禁用某个数据库表的所有触发器 Alter table table_name DISABLE ALL TRIGGERS; 3、删除触发器 (1)删除触发器 Drop TRIGGER trigger_name; (2)必须要具有删除的权限 但每次只能删除一个触发器,而且触发器的创建者必须要具有DROP ANY TIRGGER的系统权限。 4、利用USER_TRIGGERS 数据字典视图查看有关触发器的信息 1、子曰:“学而不思则罔,思而不学则殆。” “学而时习之” 2、子曰:“知之者不如好之者,好之者不如乐之者” 3、子曰:“三人行,必有我师焉” 4、子曰:“我非生而知之者,好古,敏以求之者也” 本讲的简要回顾 5、师者:“传道、授业和解惑” PLSQL异常和Oracle触发器 PLSQL异常和Oracle触发器 PLSQL 代码中的异常 异常捕获和处理示例 Oracle数据库中的触发器 DML类型的触发器及应用 替代类型的触发器及应用 管理和控制触发器 在本单元重点了解如下知识点 一、PLSQL 代码中的异常 1、PL/SQL用异常和异常处理器来实现错误处理 (1)区分编译时错误和运行时错误的不同 在Oracle的应用开发中出现错误的情形通常分为编译时错误(Compile-time Error)和运行时错误(Run-time Error)。 而在运行时所出现的各种错误,一般都归纳为异常。因此,如果不对异常进行处理,很可能会中断当前程序的运行过程。 (2)Oracle中的异常处理的特性 PL/SQL处理异常不同于其他程序语言的错误管理方法,PL/SQL的异常处理机制与ADA(针对嵌入式和实时系统设计的语言)很相似 Oracle允许声明其他异常条件类型以扩展错误/异常处理,这种扩展使PL/SQL的异常处理非常灵活。 2、PL/SQL代码中的异常种类 (1)系统中预定义的异常 当PL/SQL语句在执行中违背了Oracle原则或超越了系统依赖的原则就会隐式地产生出内部的异常。在PL/SQL中异常通过名字处理预定义异常,预定义的一些异常名称: NO_DATA_FOUND:没有找到数据 TOO_MANY_ROWS:找到多行数据 INVALID_CURSOR:失效的游标 ZERO_DIVIDE:除数为零 DUP_VAL_ON_INDEX:唯一索引中插入了重复值 (2)用户自定义异常 由于用户定义的异常不一定是系统错误,因此Oracle系统不会自动触发,需要在声明部分定义出。 (3)用户定义的异常处理部分的语法和规则基本上和预定义的异常处理相同 在应用用户自定义异常时需要经过三个环节:声明异常类型、捕获自定义异常和抛出自定义异常。 3、异常处理定义及捕获异常 (1)异常抛出 当一个运行时错误发生时,此时也称为一个异常被抛出。但抛出异常主要有三种不同的方式: 通过PL/SQL运行时引擎 使用RAISE语句 调用RAISE_APPLICATION_ERROR存储过程当数据库或PL/SQL在运行时发生错误时,一个异常被PL/SQL运行时的引擎自动抛出。 (2)异常捕获 为了能够准确地捕获指定的异常,需要在PL/SQL程序块的异常部分包含程序处理错误的代码,当异常被抛出时,程序控制离开执行部分的流程而转入到异常处理部分。 4、异常捕获处理的语法 (1)语法定义要点 PL/SQL 语句块中的异常处理首先是保留字EXCEPTION,而其中的WHEN 子句会判断哪些异常必须被捕获。 (2)代码示例 PL/SQL 语句块中的异常处理部分包含只会在PL/SQL 语句块出现运行时错误时才会执行的语句。 5、异常捕获的基本规则 在异常捕获的语句块中的when子句的数量没有限制,当异常抛出后,代码的控制流程无条件地转到异常处理部分。其中的EXCEPTION 关键词开始异常处理部分,而WHEN OTHERS 必须为最后的一条子句。 但在异常语句块中,最终只有一个句柄所代表的异常代码会被处理和执行。 6、与异常捕获相关的函数 (1)SQLCODE返回错误代码(序号) Oracle内置函数SQLCODE和SQLERRM分别用来返回Oracle的错误代码和错误消息。 (2)SQLERRM返回与错误代码关联的消息 (3)代码示例 对于用户自定义的异常,SQLCODE返回的是+1,而SQLERRM返回的是User-Defined Exception

文档评论(0)

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

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

1亿VIP精品文档

相关文档