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

  • 3
  • 0
  • 约6千字
  • 约 33页
  • 2018-10-11 发布于湖北
  • 举报

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

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

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)

1亿VIP精品文档

相关文档