欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    oracle常见错误.docx

    • 资源ID:7321351       资源大小:34.33KB        全文页数:35页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    oracle常见错误.docx

    1、oracle常见错误命名的系统异常 产生原因 access_into_null 未定义对象 case_not_found case中若未包含相应的when,并且没有设置 collection_is_null 集合元素未初始化 curser_already_open 游标已经打开 dup_val_on_index 唯一索引对应的列上有重复的值 invalid_cursor 在不合法的游标上进行操作 invalid_number 内嵌的 sql 语句不能将字符转换为数字 no_data_found 使用 select into 未返回行,或应用索引表未初始化的 too_many_rows 执行 s

    2、elect 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

    3、内部问题,可能需要重装数据字典 pl./sql系统包 统包 rowtype_mismatch 主游标变量与 pl/sql 游标变量的返回类型不兼容 self_is_null 使用对象类型时,在 null 对象上调用对象方法 storage_error 运行 pl/sql 时,超出内存空间 sys_invalid_id 无效的 rowid 字符串 timeout_on_resource oracle 在等待资源时超时1、异常的优点 如果没有异常,在程序中,应当检查每个命令的成功还是失败,如 BEGIN SELECT . - check for no data found error SELECT

    4、 . - check for no data found error SELECT . - check for no data found error 这种实现的方法缺点在于错误处理没有与正常处理分开,可读性差,使用异常,可以方便处理错误,而且异常处理程序与正常的事务逻辑分开,提高了可读性,如 BEGIN SELECT . SELECT . SELECT . . EXCEPTION WHEN NO_DATA_FOUND THEN - catches all no data found errors 2、异常的分类 有两种类型的异常,一种为内部异常,一种为用户自定义异常,内部异常是执行期间返回到

    5、PL/SQL块的ORACLE错误或由PL/SQL代码的某操作引起的错误,如除数为零或内存溢出的情况。用户自定义异常由开发者显示定义,在PL/SQL块中传递信息以控制对于应用的错误处理。 每当PL/SQL违背了ORACLE原则或超越了系统依赖的原则就会隐式的产生内部异常。因为每个ORACLE错误都有一个号码并且在PL/SQL中异常通过名字处理,ORACLE提供了预定义的内部异常。如SELECT INTO 语句不返回行时产生的ORACLE异常NO_DATA_FOUND。对于预定义异常,现将最常用的异常列举如下: exception oracle error sqlcode value condit

    6、ion no_data_found ora-01403 +100 select into 语句没有符合条件的记录返回 too_many_rows ora-01422 -1422 select into 语句符合条件的记录有多条返回 dup_val_on_index ora-00001 -1 对于数据库表中的某一列,该列已经被限制为唯一索引,程序试图存储两个重复的值 value_error ora-06502 -6502 在转换字符类型,截取或长度受限时,会发生该异常,如一个字符分配给一个变量,而该变量声明的长度比该字符短,就会引发该异常 storage_error ora-06500 -650

    7、0 内存溢出 zero_divide ora-01476 -1476 除数为零 case_not_found ora-06592 -6530 对于选择case语句,没有与之相匹配的条件,同时,也没有else语句捕获其他的条件 cursor_already_open ora-06511 -6511 程序试图打开一个已经打开的游标 timeout_on_resource ora-00051 -51 系统在等待某一资源,时间超时 如果要处理未命名的内部异常,必须使用OTHERS异常处理器或PRAGMA EXCEPTION_INIT 。PRAGMA由编译器控制,或者是对于编译器的注释。PRAGMA在编

    8、译时处理,而不是在运行时处理。EXCEPTION_INIT告诉编译器将异常名与ORACLE错误码结合起来,这样可以通过名字引用任意的内部异常,并且可以通过名字为异常编写一适当的异常处理器。 在子程序中使用EXCEPTION_INIT的语法如下: PRAGMA EXCEPTION_INIT(exception_name, -Oracle_error_number); 在该语法中,异常名是声明的异常,下例是其用法: DECLARE deadlock_detected EXCEPTION; PRAGMA EXCEPTION_INIT(deadlock_detected, -60); BEGIN .

    9、- Some operation that causes an ORA-00060 error EXCEPTION WHEN deadlock_detected THEN - handle the error END; 对于用户自定义异常,只能在PL/SQL块中的声声明部分明异常,异常的名字由EXCEPTION关键字引入: reserved_loaned Exception 产生异常后,控制传给了子程序的异常部分,将异常转向各自异常控制块,必须在代码中使用如下的结构处理错误: Exception When exception1 then Sequence of statements; When

    10、 exception2 then Sequence of statements; When others then 3、异常的抛出 由三种方式抛出异常 1 通过PL/SQL运行时引擎 2. 使用RAISE语句 3. 调用RAISE_APPLICATION_ERROR存储过程 当数据库或PL/SQL在运行时发生错误时,一个异常被PL/SQL运行时引擎自动抛出。异常也可以通过RAISE语句抛出 RAISE exception_name; 显式抛出异常是程序员处理声明的异常的习惯用法,但RAISE不限于声明了的异常,它可以抛出任何任何异常。例如,你希望用TIMEOUT_ON_RESOURCE错误检测

    11、新的运行时异常处理器,你只需简单的在程序中使用下面的语句: RAISE TIMEOUT_ON_RESOUCE; 比如下面一个订单输入的例子,若当订单小于库存数量,则抛出异常,并且捕获该异常,处理异常 DECLARE inventory_too_low EXCEPTION; -其他声明语句 BEGIN IF order_rec.qtyinventory_rec.qty THEN RAISE inventory_too_low; END IF EXCEPTION WHEN inventory_too_low THEN order_rec.staus:=backordered; END; RAISE

    12、_APPLICATION_ERROR内建函数用于抛出一个异常并给异常赋予一个错误号以及错误信息。自定义异常的缺省错误号是+1,缺省信息是User_Defined_Exception。RAISE_APPLICATION_ERROR函数能够在pl/sql程序块的执行部分和异常部分调用,显式抛出带特殊错误号的命名异常。 Raise_application_error(error_number,message,true,false) 错误号的范围是-20,000到-20,999。错误信息是文本字符串,最多为2048字节。TRUE和FALSE表示是添加(TRUE)进错误堆(ERROR STACK)还是覆

    13、盖(overwrite)错误堆(FALSE)。缺省情况下是FALSE。 如下代码所示: IF product_not_found THEN RAISE_APPLICATION_ERROR(-20123,Invald product code TRUE); END IF; 4、异常的处理 PL/SQL程序块的异常部分包含了程序处理错误的代码,当异常被抛出时,一个异常陷阱就自动发生,程序控制离开执行部分转入异常部分,一旦程序进入异常部分就不能再回到同一块的执行部分。下面是异常部分的一般语法: EXCEPTION WHEN exception_name THEN Code for handing e

    14、xception_name WHEN another_exception THEN Code for handing another_exception WHEN others THEN code for handing any other exception. 用户必须在独立的WHEN子串中为每个异常设计异常处理代码,WHEN OTHERS子串必须放置在最后面作为缺省处理器处理没有显式处理的异常。当异常发生时,控制转到异常部分,ORACLE查找当前异常相应的WHEN.THEN语句,捕捉异常,THEN之后的代码被执行,如果错误陷阱代码只是退出相应的嵌套块,那么程序将继续执行内部块END后面的语

    15、句。如果没有找到相应的异常陷阱,那么将执行WHEN OTHERS。在异常部分WHEN 子串没有数量限制。 EXCEPTION WHEN inventory_too_low THEN order_rec.staus:=backordered; replenish_inventory(inventory_nbr= inventory_rec.sku,min_amount=order_rec.qty-inventory_rec.qty); WHEN discontinued_item THEN -code for discontinued_item processing WHEN zero_divi

    16、de THEN -code for zero_divide WHEN OTHERS THEN -code for any other exception END; 当异常抛出后,控制无条件转到异常部分,这就意味着控制不能回到异常发生的位置,当异常被处理和解决后,控制返回到上一层执行部分的下一条语句。 BEGIN DECLARE bad_credit exception; BEGIN RAISE bad_credit; -发生异常,控制转向; EXCEPTION WHEN bad_credit THEN dbms_output.put_line(bad_credit); END; -bad_cr

    17、edit异常处理后,控制转到这里 EXCEPTION WHEN OTHERS THEN -控制不会从bad_credit异常转到这里 -因为bad_credit已被处理 END; 当异常发生时,在块的内部没有该异常处理器时,控制将转到或传播到上一层块的异常处理部分。 BEGIN DECLARE -内部块开始 bad_credit exception; BEGIN RAISE bad_credit; -发生异常,控制转向; EXCEPTION WHEN ZERO_DIVIDE THEN -不能处理bad_credite异常 dbms_output.put_line(divide by zero

    18、error); END -结束内部块 -控制不能到达这里,因为异常没有解决; -异常部分 EXCEPTION WHEN OTHERS THEN -由于bad_credit没有解决,控制将转到这里 END; 5、异常的传播 没有处理的异常将沿检测异常调用程序传播到外面,当异常被处理并解决或到达程序最外层传播停止。在声明部分抛出的异常将控制转到上一层的异常部分。 BEGIN executable statements BEGIN today DATE:=SYADATE; -ERRROR BEGIN -内部块开始 dbms_output.put_line(this line will not exe

    19、cute); EXCEPTION WHEN OTHERS THEN -异常不会在这里处理 END;-内部块结束 EXCEPTION WHEN OTHERS THEN 处理异常 END -处理 oracle 系统自动生成系统异常外,可以使用 raise 来手动生成错误。l Raise exception;l Raise package.exception;l Raise;以上是 raise 的三种使用方法。第一种用于生成当前程序中定义的异常或在 standard 中的系统异常。 Declare Invalid_id exception; Id_values varchar(2); Begin I

    20、d_value:=id_for(smith); If substr(id_value,1,1)!=x Then Raise invalid_id; End if; Exception When invalid_id Then Dbms_output.put_line(this is an invalid id!); End;这是一个生成自定义异常的例子,当然也可以生成系统异常: declare employee_id_in number; BeginSelect employee_id into employee_id_in from employ_list where employee_na

    21、me=&n;If employee_id_in=0Then Raise zero_devided;End if; Exception When zero_devided Then Dbms_output.put_line(wrong!); End;有一些异常是定义在非标准包中的,如 UTL_FILE , DBMS_SQL 以及程序员创建的包中异常。可以使用 raise 的第二种用法来生成异常。 If day_overdue(isbn_in, browser_in) 365 Then Raise overdue_pkg.book_is_lost End if;在最后一种 raise 的形式中,不

    22、带任何参数。这种情况只出现在希望将当前的异常传到外部程序时。 Exception When no_data_found Then Raise; End; Pl.sql 使用 raise_application_error 过程来生成一个有具体描述的异常。当使用这个过程时,当前程序被中止,输入输出参数被置为原先的值,但任何 DML 对数据库所做的改动将被保留,可以在之后用 rollback 命令回滚。下面是该过程的原型: Procedure raise_application_error( Num binary_integer; Msg varchar2; Keeperrorstack Bool

    23、ean default false)其中 num 是在 -20999 到 -20000 之间的任何数字(但事实上, DBMS_OUPUT 和 DBMS_DESCRIBLE 包使用了 -20005 到 -20000 的数字); msg 是小于 2K 个字符的描述语,任何大于 2K 的字符都将被自动丢弃; keeperrorstack 默认为 false ,是指清空异常栈,再将当前异常入栈,如果指定 true 的话就直接将当前异常压入栈中。 CREATE OR REPLACE PROCEDURE raise_by_language (code_in IN PLS_INTEGER) IS l_mes

    24、sage error_table.error_string%TYPE; BEGIN SELECT error_string INTO l_message FROM error_table, v$nls_parameters v WHERE error_number = code_in AND string_language = v.VALUE AND v.parameter = NLS_LANGUAGE; RAISE_APPLICATION_ERROR (code_in, l_message); END;ORACL内部异常:ORA-00001: 违反唯一约束条件 (.) ORA-00017:

    25、请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-00020: 超出最大进程数 () ORA-00021: 会话附属于其它某些进程;无法转换会话 ORA-00022: 无效的会话 ID;访问被拒绝 ORA-00023: 会话引用进程私用内存;无法分离会话 ORA-00024: 单一进程模式下不允许从多个进程注册 ORA-00025: 无法分配 ORA-00026: 丢失或无效的会话 ID ORA-00027: 无法删去当前会话 ORA-00028: 您的会话己被删去 ORA-00029: 会话不是用户会话 ORA-00030: 用户

    26、会话 ID 不存在。 ORA-00031: 标记要删去的会话 ORA-00032: 无效的会话移植口令 ORA-00033: 当前的会话具有空的移植口令 ORA-00034: 无法在当前 PL/SQL 会话中 ORA-00035: LICENSE_MAX_USERS 不能小于当前用户数 ORA-00036: 超过递归 SQL () 级的最大值 ORA-00037: 无法转换到属于不同服务器组的会话 ORA-00038: 无法创建会话: 服务器组属于其它用户 ORA-00050: 获取入队时操作系统出错 ORA-00051: 等待资源超时 ORA-00052: 超出最大入队资源数 () ORA-

    27、00053: 超出最大入队数 ORA-00054: 资源正忙,要求指定 NOWAIT ORA-00055: 超出 DML 锁的最大数 ORA-00056: 对象 . 上的 DDL 锁以不兼容模式挂起 ORA-00057: 超出临时表锁的最大数 ORA-00058: DB_BLOCK_SIZE 必须为才可安装此数据库 (非 ) ORA-00059: 超出 DB_FILES 的最大值 ORA-00060: 等待资源时检测到死锁 ORA-00061: 另一个例程设置了不同的 DML_LOCKS ORA-00062: 无法获得 DML 全表锁定;DML_LOCKS 为 0 ORA-00063: 超出 LOG_FILES 的最大数 ORA-00064: 对象过大以至无法分配在此 O/S (,) ORA-00065: FIXED_DATE 的初始化失败 ORA-00066: LOG_FILES 为 但需要成为 才可兼容 ORA-00067: 值 对参数 无效;至少必须为 ORA-00068: 值 对参数 无效,必须在 和 之间 ORA-00069: 无法获得锁定 - 禁用了表锁定 ORA-00070: 命令无效 ORA-00071: 进程号必须介于 1 和 之间 ORA-00072: 进程不活动 ORA-00073: 命


    注意事项

    本文(oracle常见错误.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开