异常是oracle 数据库中的 PL/SQL 代码在执行期间出现的错误。无论任何时候,当PL/SQL引擎执行代码时,都可能会遇到异常,当产生异常时,PL/SQL会将程序控制转到程序块的异常处理部分。
如果在程序块中没有异常处理,那么异常就会传播,或者发往程序块德调用者。
Oracle 有3种类型的异常
l 预定义异常
对这种异常的处理,无须在程序中定义,由oracle 自动将其引发
l 非预定义异常
即其他标准的oracle 错误。对这种异常的处理,需要用户在程序中定义然后由oracle 自动将其引发。
l 自定义异常
如果程序设计人员认为某种情况违反了业务逻辑,则设计人员可明确定义并引发异常
异常处理部分一般放在PL/SQL程序的后半部分,其结构如下:
EXCEPTION
WHEN first_exception THEN <code to handle first exception>
WHEN second_exception THEN <code to handle second exception>
WHEN OTHERS THEN <code to handle orthers exception>
END;
预定义异常
我们现在以已存在主键进行添加数据时捕获异常为例
SQL> set serveroutput on;
SQL>
SQL> begin
2 insert into emp(empno,ename,job,deptno)
3 values('7394','Longmanfei','stu',20);
4 exception
5 when dup_val_on_index then //dup_val_on_index注意这个异常的定义是oracle 规定的专门针对这种插入主键重复数据的
6 dbms_output.put_line('捕获到了异常');
7 dbms_output.put_line('该主键已存在');
8 end;
9 /
捕获到了异常
该主键已存在
PL/SQL procedure successfully completed
下面列举一下oracle 预定义的 异常
DUP_VAL_ON_INDEX
|
试图破坏一个唯一性限制
|
Timeout-on-resource
|
在等待资源时发生超时
|
Transanction-backed-out
|
由于发生死锁,事务被撤销
|
Invalid-CURSOR
|
视图使用一个无效的游标
|
Not-logged-on
|
没有连接到oracle
|
Login-denied
|
无效的用户名/口令
|
NO_DATA_FOUND
|
Select into 没有找到数据
|
TOO_MANY_ROWS
|
Select into 返回多行
|
Access-INTO-null
|
试图为null对象的属性赋值
|
等等
|
|
非预定义异常
对于非预定义异常,必须先对定义的oracle 错误进行定义
1. <异常情况> exception
例如定义一个 Fk_DELETE EXCEPTION
2. 使用exception_into 语句将已定义好的异常情况与标准的oracle 错误联系起来
PRAGMA EXCEPTION_INTO(<异常情况>,<错误代码>);
自定义异常
<异常情况> exception
PAISE <异常情况>
之后
Declare
ex_update exception;
Begin
Update 商品信息
Set 单价=单价-100
Where 商品编号='1030';
If sql%notfound then
RAISE ex_update;
End if;
Exception
When ex_update then
dbms_output.put_line('捕捉到自定义异常');
dbms_output.put_line('未更新任何行');
End;
/
<!--EndFragment-->
分享到:
相关推荐
Oracle异常处理是数据库管理和应用程序开发中的关键环节,它涉及到对程序执行过程中可能出现的错误和异常情况进行有效管理和响应。Oracle数据库,作为一款广泛使用的商业关系型数据库管理系统,提供了强大的异常处理...
oracle笔记异常处理,异常处理的代码案例和知识点笔记!
根据ORACLE提供的异常处理机制,我们可以将异常分为三类: 1. **预定义异常**:这是由ORACLE系统预先定义好的一组异常,当特定的错误发生时,系统会自动抛出相应的异常。例如,在尝试插入一条已经存在的记录到具有...
这个是oracle课成异常处理章节后面的部分习题答案,大概四五道题的答案。
总结来说,Oracle异常处理是通过预定义和自定义异常来实现的,它增强了程序对错误的响应能力,帮助开发者在遇到问题时能够有序地处理,避免程序崩溃,保证系统的正常运行。理解并熟练掌握Oracle的异常处理机制,对于...
Oracle 存储过程异常处理 Oracle 存储过程异常处理是指在 Oracle 数据库中使用存储过程时出现的异常情况的处理方法。异常处理是指在程序执行过程中出现错误或异常时,采取相应的处理措施,以确保程序的可靠性和...
Oracle 异常处理是 PL/SQL 编程中不可或缺的一部分,它允许开发者优雅地处理程序运行时遇到的各种错误。在 PL/SQL 中,异常处理主要分为预定义异常、非预定义异常以及自定义异常。 预定义异常是 Oracle 为常见错误...
Oracle 异常处理是PL/SQL编程中的关键组成部分,它允许开发者优雅地处理程序执行过程中可能出现的错误,确保系统的稳定性和可靠性。异常处理是通过异常情况(EXCEPTION)和异常处理器(EXCEPTION HANDLER)来实现的...
Others 异常处理器将对所有语法的异常情态进行处理,一般放在异常处理的最后,可以保证所有的错误都被检测到。 Oracle 异常及触发器提供了一种有效的错误处理机制,可以帮助程序员更好地处理程序执行过程中的错误。
Oracle 存储过程 exception 异常处理大全及实例经典最终 Oracle 存储过程 exception 异常处理大全及实例经典最终是 Oracle 数据库中存储过程的异常处理机制。异常处理是指在程序执行过程中出现的错误或未预料到的...
oracle异常处理步骤自己总结的,不太成熟,大家可以不看,只是我的备忘录
### Oracle异常处理归纳 本文将基于提供的文档信息对Oracle中常见的异常问题进行归纳总结,并提供相应的解决方案。这些异常包括但不限于`ORA-12651:TNS:没有监听器`、`ORA-12545:因目标主机和对象不存在,连接失败`...
Oracle异常处理基于PL/SQL(Procedural Language/Structured Query Language),这是一种扩展SQL,允许开发者编写带有流程控制、循环、条件判断等结构化编程元素的存储过程。在PL/SQL中,异常是程序运行时发生的问题...
下面,我们将深入探讨一些常见的Oracle异常及其解决策略。 1. **NO_DATA_FOUND** (ORA-01403): 当执行`SELECT INTO`语句时,如果没有返回任何数据,系统会抛出此异常。为了避免程序中断,可以使用`EXCEPTION WHEN ...
#### 一、Oracle异常处理机制简介 在Oracle PL/SQL编程中,异常处理是一项非常重要的功能。它可以帮助开发者捕获并处理程序运行时可能发生的错误情况,确保应用程序能够稳定可靠地运行。Oracle PL/SQL支持多种类型...
"Oracle SGA 参数调整导致数据库启动异常处理方法" 在 Oracle 数据库中,SGA(System Global Area)参数调整可能会导致数据库启动异常。这种情况下,需要了解 SGA 参数的调整方法和恢复数据库的方法。 一、SGA ...
在Oracle数据库中,游标(Cursor)和异常处理(Exception Handling)是PL/SQL编程的重要组成部分,它们在处理复杂逻辑和确保数据完整性方面起到关键作用。以下是对这两个主题的详细阐述。 首先,让我们来理解Oracle...
ORACLE 用户自定义异常小例子 1.进入pl/sql测试窗口 2.执行语句 declare empname varchar2(255); customize_exp EXCEPTION; –自定义异常 begin FOR c IN (select d.* from scott.dept d) ...
### Oracle游标与异常处理详解 #### 一、Oracle游标概述 **游标**是Oracle SQL中的一个重要概念,主要用于处理从数据库中提取的数据。它提供了在程序中逐行访问和处理查询结果的能力。 ##### 1.1 游标概念 - **...