`

Oracle异常

阅读更多

一、在plsql中,oracle自带的Exceptions如下:

Exception Oracle Error SQLCODE Value
ACCESS_INTO_NULL ORA-06530 -6530
CASE_NOT_FOUND ORA-06592 -6592
COLLECTION_IS_NULL ORA-06531 -6531
CURSOR_ALREADY_OPEN ORA-06511 -6511
DUP_VAL_ON_INDEX ORA-00001 -1
INVALID_CURSOR ORA-01001 -1001
INVALID_NUMBER ORA-01722 -1722
LOGIN_DENIED ORA-01017 -1017
NO_DATA_FOUND ORA-01403 +100
NOT_LOGGED_ON ORA-01012 -1012
PROGRAM_ERROR ORA-06501 -6501
ROWTYPE_MISMATCH ORA-06504 -6504
SELF_IS_NULL ORA-30625 -30625
STORAGE_ERROR ORA-06500 -6500
SUBSCRIPT_BEYOND_COUNT ORA-06533 -6533
SUBSCRIPT_OUTSIDE_LIMIT ORA-06532 -6532
SYS_INVALID_ROWID ORA-01410 -1410
TIMEOUT_ON_RESOURCE ORA-00051 -51
TOO_MANY_ROWS ORA-01422 -1422
VALUE_ERROR ORA-06502 -6502
ZERO_DIVIDE ORA-01476 -1476

 

以上没有列出的oracle error可以通过如下方式截获
when others then
if sqlcode=[需要处理错误的oracle error code value] then
...
end if

二、自定义异常,示例如下:
--申明
DECLARE inventory_too_low EXCEPTION;
--抛出
IF order_rec.qty>inventory_rec.qty THEN
RAISE inventory_too_low;
END IF
--截获
EXCEPTION
 WHEN inventory_too_low THEN
 END;

 

此段摘自:http://techkb.it168.com/Articles/f/3/0/f303899469bf8c704d9fc6ca89efd443.htm

 


Oracle异常名称
 错误号
 说明
 
DUP_VAL_ON_INDEX
 ORA-00001
 You tried to execute an INSERT or UPDATE statement that has created a duplicate value in a field restricted by a unique index.试图破坏一个唯一性限制
 
TIMEOUT_ON_RESOURCE
 ORA-00051
 You were waiting for a resource and you timed out.在等待资源时发生超时
 
TRANSACTION_BACKED_OUT
 ORA-00061
 The remote portion of a transaction has rolled back.由于发生死锁事务被撤消
 
INVALID_CURSOR
 ORA-01001
 You tried to reference a cursor that does not yet exist. This may have happened because you’ve executed a FETCH cursor or CLOSE cursor before OPENing the cursor.试图使用一个未打开的游标
 
NOT_LOGGED_ON
 ORA-01012
 You tried to execute a call to Oracle before logging in.没有连接到ORACLE
 
LOGIN_DENIED
 ORA-01017
 You tried to log into Oracle with an invalid username/password combination.无效的用户名/口令
 
NO_DATA_FOUND
 ORA-01403
 SELECT INTO没有找到数据You tried one of the following:

You executed a SELECT INTO statement and no rows were returned.You referenced an uninitialized row in a table.You read past the end of file with the UTL_FILE package.
TOO_MANY_ROWS
 ORA-01422
 SELECT INTO 返回多行You tried to execute a SELECT INTO statement and more than one row was returned.
 
ZERO_DIVIDE
 ORA-01476
 试图被零除You tried to divide a number by zero.
 
INVALID_NUMBER
 ORA-01722
 转换一个数字失败You tried to execute an SQL statement that tried to convert a string to a number, but it was unsuccessful.
 
STORAGE_ERROR
 ORA-06500
 内存不够或内存被破坏引发的内部错误You ran out of memory or memory was corrupted.
 
PROGRAM_ERROR
 ORA-06501
 内部错误,需重新安装数据字典视图和pl/sql包This is a generic “Contact Oracle support” message because an internal problem was encountered.
 
VALUE_ERROR
 ORA-06502
 赋值操作,变量长度不足,触发该异常You tried to perform an operation and there was a error on a conversion, truncation, or invalid constraining of numeric or character data.
 
ROWTYPE_MISMATCH
 ORA-6504
 宿主游标变量与 PL/SQL变量有不兼容行类型
 
CURSOR_ALREADY_OPEN
 ORA-06511
 试图打开一个已打开的游标You tried to open a cursor that is already open.
 
ACCESS_INTO_NULL
 ORA-6530
 试图为null 对象的属性赋值
 
COLLECTION_IS_NULL
 ORA-6531
 试图给没有初始化的嵌套表变量或者Varry变量赋值
 
SUBSCRIPT_OUTSIDE_LIMIT
 ORA-6532
 对嵌套或varray索引使用了负数
 
SUBSCRIPT_BEYOND_COUNT
 ORA-6533
 对嵌套或varray索引的引用大于集合中元素的个数
 

本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2010-12/30876.htm

分享到:
评论

相关推荐

    ORACLE 异常错误处理

    ### ORACLE 异常错误处理详解 #### 一、异常处理概述 在ORACLE数据库的开发过程中,无论是多么复杂的业务逻辑还是简单的数据操作,都不可避免地会遇到各种异常情况。有效的异常处理机制不仅可以帮助开发者更好地...

    oracle异常及触发器.pptx

    Oracle 异常及触发器 Oracle 异常是一种运行时错误处理机制,可以捕捉和处理程序执行过程中的错误。异常可以分为预定义异常和用户定义异常两种。 预定义异常是 Oracle 提供的预定义错误类型,例如 Invalid_cursor...

    oracle异常处理

    Oracle 异常处理是 PL/SQL 编程中不可或缺的一部分,它允许开发者优雅地处理程序运行时遇到的各种错误。在 PL/SQL 中,异常处理主要分为预定义异常、非预定义异常以及自定义异常。 预定义异常是 Oracle 为常见错误...

    ORACLE异常处理剖析.pdf

    Oracle异常处理是数据库管理和应用程序开发中的关键环节,它涉及到对程序执行过程中可能出现的错误和异常情况进行有效管理和响应。Oracle数据库,作为一款广泛使用的商业关系型数据库管理系统,提供了强大的异常处理...

    Oracle Exception汇总(自定义Oracle异常)

    下面,我们将深入探讨一些常见的Oracle异常及其解决策略。 1. **NO_DATA_FOUND** (ORA-01403): 当执行`SELECT INTO`语句时,如果没有返回任何数据,系统会抛出此异常。为了避免程序中断,可以使用`EXCEPTION WHEN ...

    oracle 异常处理剖析共.pdf

    总结来说,Oracle异常处理是通过预定义和自定义异常来实现的,它增强了程序对错误的响应能力,帮助开发者在遇到问题时能够有序地处理,避免程序崩溃,保证系统的正常运行。理解并熟练掌握Oracle的异常处理机制,对于...

    oracle异常处理课后答案

    这个是oracle课成异常处理章节后面的部分习题答案,大概四五道题的答案。

    oracle异常和游标管理.pptx

    Oracle 异常和游标管理 Oracle 异常是指在 PL/SQL 程序执行过程中出现的错误或异常情况。异常可以是预定义的,也可以是用户定义的。在本节中,我们将详细讨论 Oracle 异常和游标管理。 异常类型 ---------- 在 ...

    ch03 oracle异常异常与动态sql

    本章我们将深入探讨“Oracle异常处理”以及“动态SQL”的相关知识点。 异常处理是编程中的一个关键环节,尤其是在Oracle数据库环境中。Oracle提供了完善的异常处理机制,使得开发人员能够优雅地捕获并处理错误,...

    ORACLE 异常处理总结.doc

    Oracle 异常处理是PL/SQL编程中的关键组成部分,它允许开发者优雅地处理程序执行过程中可能出现的错误,确保系统的稳定性和可靠性。异常处理是通过异常情况(EXCEPTION)和异常处理器(EXCEPTION HANDLER)来实现的...

    oracle异常处理归纳.docx

    ### Oracle异常处理归纳 本文将基于提供的文档信息对Oracle中常见的异常问题进行归纳总结,并提供相应的解决方案。这些异常包括但不限于`ORA-12651:TNS:没有监听器`、`ORA-12545:因目标主机和对象不存在,连接失败`...

    oracle patch scn--修改oracle scn工具(oracle异常恢复利器)

    oracle scn修改工具,可以直接修改oracle scn,在极端情况下恢复使用,比如解决ORA-600 2662等类似错误,使用说明:https://www.xifenfei.com/2022/06/win-oracle-scn-patch.html

    oralce异常信息对照表

    Oracle异常主要分为预定义异常(predefined exceptions)和用户自定义异常(user-defined exceptions)。预定义异常是Oracle系统预先定义好的,它们与SQL语句执行过程中可能遇到的错误相对应,如NO_DATA_FOUND(试图...

    oracle异常总结

    Oracle 异常处理是 PL/SQL 编程中不可或缺的一部分,它允许开发者优雅地处理运行时错误,确保程序的稳定性和可维护性。在Oracle数据库中,异常分为预定义异常、非预定义异常和自定义异常。 预定义异常是Oracle为...

    Oracle 异常处理

    Oracle异常处理基于PL/SQL(Procedural Language/Structured Query Language),这是一种扩展SQL,允许开发者编写带有流程控制、循环、条件判断等结构化编程元素的存储过程。在PL/SQL中,异常是程序运行时发生的问题...

    oracle自定义异常

    #### 一、Oracle异常处理机制简介 在Oracle PL/SQL编程中,异常处理是一项非常重要的功能。它可以帮助开发者捕获并处理程序运行时可能发生的错误情况,确保应用程序能够稳定可靠地运行。Oracle PL/SQL支持多种类型...

    oracle笔记异常处理

    oracle笔记异常处理,异常处理的代码案例和知识点笔记!

    Oracle异常关闭导致的故障及解决办法

    Oracle shutdown的时候突然断电,导致使用sql/plus启动时无法连接到数据库,具体描述为:connection can not permitted, shut in progress。文中介绍了对此问题的解决办法。

Global site tag (gtag.js) - Google Analytics