Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 497|回复: 0

Oracle预定义的21个系统异常类型

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-6-29 11:19:43 | 显示全部楼层 |阅读模式

     

     
     
    Oracle预定义的21个系统异常类型

    命名的系统异常

    产生原因

    ACCESS_INTO_NULL

    未定义对象

    CASE_NOT_FOUND

    CASE 中若未包含相应的 WHEN ,并且没有设置 ELSE 时

    COLLECTION_IS_NULL

    集合元素未初始化

    CURSER_ALREADY_OPEN

    游标已经打开

    DUP_VAL_ON_INDEX

    唯一索引对应的列上有重复的值

    INVALID_CURSOR

    在不合法的游标上进行操作

    INVALID_NUMBER

    内嵌的 SQL 语句不能将字符转换为数字

    NO_DATA_FOUND

    使用 select into 未返回行,或应用索引表未初始化的元素时

    TOO_MANY_ROWS

    执行 select into 时,结果集超过一行

    ZERO_DIVIDE

    除数为 0

    SUBSCRIPT_BEYOND_COUNT

    元素下标超过嵌套表或 VARRAY 的最大值

    SUBSCRIPT_OUTSIDE_LIMIT

    使用嵌套表或 VARRAY 时,将下标指定为负数

    VALUE_ERROR

    赋值时,变量长度不足以容纳实际数据

    LOGIN_DENIED

    PL/SQL 应用程序连接到 oracle 数据库时,提供了不正确的用户名或密码

    NOT_LOGGED_ON

    PL/SQL 应用程序在没有连接 oralce 数据库的情况下访问数据

    PROGRAM_ERROR

    PL/SQL 内部问题,可能需要重装数据字典& pl./SQL 系统包

    ROWTYPE_MISMATCH

    宿主游标变量与 PL/SQL 游标变量的返回类型不兼容

    SELF_IS_NULL

    使用对象类型时,在 null 对象上调用对象方法

    STORAGE_ERROR

    运行 PL/SQL 时,超出内存空间

    SYS_INVALID_ID

    无效的 ROWID 字符串

    TIMEOUT_ON_RESOURCE

    Oracle 在等待资源时超时

     下面的异常带有错误代码: 

    Oracle在预定义包STANDARD包中提供了一系列的预定义异常。他们是调试Oracle PL/SQL程序的有用工具。大部分错误用负号作为错误号。可以使用SQLCODE内置函数看到错误代码,使用SQLERRM得到异常的内置消息。

    异常
    错误
    何时出现
    ACCESS_INTO_NULL ORA-06530 试图访问未初始化对象的时候出现
    CASE_NOT_FOUND ORA-06592 如果定义了一个没有ELSE子句的CASE语句,而且没有CASE语句满足运行时条件时出现该异常
    COLLECTION_IS_NULL ORA-06531 当程序去访问一个没有进行初始化的NESTED TABLE或者是VARRAY的时候,会出现该异常
    CURSOR_ALREADY_OPEN ORA-06511 游标已经被OPEN,如果再次尝试打开该游标的时候,会出现该异常
    DUP_VAL_ON_INDEX ORA-00001 如果插入一列被唯一索引约束的重复值的时候,就会引发该异常(该值被INDEX认定为冲突的)
    INVALID_CURSOR ORA-01001 不允许的游标操作,比如关闭一个已经被关闭的游标,就会引发
    INVALID_NUMBER ORA-01722 给数字值赋非数字值的时候,该异常就会发生,这个异常也会发生在批读取时候LIMIT子句返回非正数的时候
    LOGIN_DENIED ORA-01017 程序中,使用错误的用户名和密码登录的时候,就会抛出这个异常
    NO_DATA_FOUND ORA_06548 在使用SELECT INTO 结构,并且语句返回NULL值的时候;访问嵌套表中已经删除的表或者是访问INDEX BY表(联合数组)中的未初始化元素就会出现该异常
    NOT_LOGGED_ON ORA-01012 当程序发出数据库调用,但是没有连接的时候(通常,在实际与会话断开连接之后)
    PROGRAM_ERROR ORA-06501 当Oracle还未正式捕获的错误发生时常会发生,这是因为数据库大量的Object功能而发生
    ROWTYPE_MISMATCH ORA-06504 如果游标结构不适合PL/SQL游标变量或者是实际的游标参数不同于游标形参的时候发生该异常
    SELF_IS_NULL ORA-30625 调用一个对象类型非静态成员方法(其中没有初始化对象类型实例)的时候发生该异常
    STORAGE_ERROR ORA-06500 当内存不够分配SGA的足够配额或者是被破坏的时候,引发该异常
    SUBSCRIPT_BEYOND_COUNT ORA-06533 当分配给NESTED TABLE或者VARRAY的空间小于使用的下标的时候,发生该异常(类似于java的ArrayIndexOutOfBoundsException)
    SUBSCRIPT_OUTSIDE_LIMIT ORA-06532 使用非法的索引值来访问NESTED TABLE或者VARRAY的时候引发
    SYS_INVALID_ROWID ORA-01410 将无效的字符串转化为ROWID的时候引发
    TIMEOUT_ON_RESOURCE ORA-00051 当数据库不能安全锁定资源的时候引发
    TOO_MANY_ROWS ORA-01422 常见错误,在使用SELECT INTO 并且查询返回多个行时引发。如果子查询返回多行,而比较运算符为相等的时候也会引发该异常。
    USERENV_COMMITSCN_ERROR ORA-01725 只可使用函数USERENV('COMMITSCN')作为INSERT语句的VALUES子句中的顶级表达式或者作为UPDATE语句的SET子句中的右操作数
    VALUE_ERROR ORA-06502 将一个变量赋给另一个不能容纳该变量的变量时引发
    ZERO_DIVIDE ORA-01476 将某个数字除以0的时候,会发生该异常

    可以很方便的在SQL块中使用EXCEPTION来捕捉异常并且进行处理(当然,编译异常与在声明块中被抛出的异常除外,一个好的PL/SQL编程习惯是规避在声明块中进行变量的赋值操作)。如果上面的预定义异常能够满足要求,就可以使用他们。如果不满足,则可以像JAVA程序一样,定义自己的异常,并且可以使用RAISE EXCEPTION来抛出异常。

     

    参考:

    http://www.233.com/oracle/zonghe/20100803/090956831.html

    http://www.linuxidc.com/Linux/2012-10/72544.htm

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-22 21:48 , Processed in 0.192757 second(s), 30 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表