Chinaunix首页 | 论坛 | 博客
  • 博客访问: 143956
  • 博文数量: 161
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: -30
  • 用 户 组: 普通用户
  • 注册时间: 2017-09-21 21:45
文章分类
文章存档

2009年(1)

2008年(74)

2007年(48)

2006年(38)

我的朋友

分类: Oracle

2007-02-16 10:01:51

Oracle内置函数SQLCODE和SQLERRM是特别用在OTHERS处理器中,分别用来返回Oracle的错误代码和错误消息。
OTHERS处理器应该是异常处理块中的最后的异常处理器,因为它是用来捕获除了别的异常处理器处理以外的所有的Oracle异常,所以在程序的最外层使用一个OTHERS处理器的话,将可以确保所有的错误都会被检测到。
在一个内在的异常中,SQLCODE返回Oracle错误的序号,而SQLERRM返回的是相应的错误消息,错误消息首先显示的是错误代码。SQLCODE返回的是负数,除非Oracle的错误为“ORA-01403:NO DATA FOUND”(译:ORA-01403:未找到数据),当Oracle错误为“ORA-01403:NO DATA FOUND”时,其对应的SQLCODE为+100。对于用户自定义的异常,SQLCODE返回的是+1,而SQLERRM返回的是User-Defined Exception。
例如:
declare
v_date varchar2(30);
begin select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') into v_date from dual;
dbms_output.put_line(v_date||'----'||sqlerrm);
end;
/
 
运行返回:
2007-02-16 09:48:59----ORA-0000: normal, successful completion
PL/SQL procedure successfully completed.
 
如果使用sqlcode:
declare
v_date varchar2(30);
begin select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') into v_date from dual; dbms_output.put_line(v_date||'----'||sqlcode);
end;
/
 
运行返回: 2007-02-16 09:50:05----0
PL/SQL procedure successfully completed.
 
一个Oracle的错误消息最多只能包含512个字节的错误代码。如果没有异常被触发,则SQLCODE返回0,SQLERRM返回“ORA-0000:normal, successful completion”。
阅读(993) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~