Oracle内置函数SQLCODE和SQLERRM的使用
2018-03-05 18:13
405 查看
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。
一个Oracle的错误消息最多只能包含512个字节的错误代码。 如果没有异常被触发,则SQLCODE返回0,SQLERRM返回“ORA-0000:normal, successful completion”。 实例
Exception
when osi_general_error then
when OTHERS THEN
out_ErrorMsg := SUBSTR(SQLERRM,1,100);
out_ErrorNbr := ABS(SQLCODE);
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。
一个Oracle的错误消息最多只能包含512个字节的错误代码。 如果没有异常被触发,则SQLCODE返回0,SQLERRM返回“ORA-0000:normal, successful completion”。 实例
Exception
when osi_general_error then
when OTHERS THEN
out_ErrorMsg := SUBSTR(SQLERRM,1,100);
out_ErrorNbr := ABS(SQLCODE);
相关文章推荐
- Oracle内置函数SQLCODE和SQLERRM的使用
- Oracle内置函数SQLCODE和SQLERRM的使用
- Oracle内置函数SQLCODE和SQLERRM
- Oracle 异常处理函数SQLCODE和SQLERRM
- 为什么oracle的内置函数中没有leftstr,rightstr之类的字符串函数(substr使用说明大全) 转
- Oracle PL/SQL开发基础(第三十二弹:SQLCODE和SQLERRM)
- ORACLE中SQLERRM、SQLCODE的信息区别
- oracle中sqlcode和sqlerrm用法
- Oracle SQL 内置函数的使用方法及结果
- oracle中sqlcode和sqlerrm用法
- PLSQL使用SQLCODE和SQLERRM的小例子
- oracle内置函数 wmsys.wm_concat使用
- oracle 中 sqlcode sqlerrm
- oracle内置函数 wmsys.wm_concat使用
- 【转】oracle内置函数 trunc 使用
- oracle 失败处理 SQLCODE和SQLERRM
- oracle内置函数 trunc 使用
- 为什么oracle的内置函数中没有leftstr,rightstr之类的字符串函数(substr使用说明大全)
- oracle内置函数 trunc 使用
- 在oracle中使用having关键字来限制你的分组结果