内置函数 SQL CODE 和 SQLERRM 是特别用在 OTHERS 处理器中,分别用来返回 Oracle 的错误代码和错误消息。 OTHERS 处理器应该是异常处理块中的最后的" name="description" />

Oracle SQLCODE/SQLERRM

发表于:2007-06-22来源:作者:点击数: 标签:
Oracle MI LY: 宋体; mso-ascii-font-family: Times New Roman; mso-hansi-font-family: Times New Roman">内置函数 SQL CODE 和 SQLERRM 是特别用在 OTHERS 处理器中,分别用来返回 Oracle 的错误代码和错误消息。 OTHERS 处理器应该是异常处理块中的最后的

   

 

OracleMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'">内置函数SQLCODESQLERRM是特别用在OTHERS处理器中,分别用来返回Oracle的错误代码和错误消息。

OTHERS处理器应该是异常处理块中的最后的异常处理器,因为它是用来捕获除了别的异常处理器处理以外的所有的Oracle异常,所以在程序的最外层使用一个OTHERS处理器的话,将可以确保所有的错误都会被检测到。

在一个内在的异常中,SQLCODE返回Oracle错误的序号,而SQLERRM返回的是相应的错误消息,错误消息首先显示的是错误代码。SQLCODE返回的是负数,除非Oracle的错误为“ORA-01403NO DATA FOUND”(译:ORA-01403:未找到数据),当Oracle错误为“ORA-01403NO DATA FOUND”时,其对应的SQLCODE+100。对于用户自定义的异常,SQLCODE返回的是+1,而SQLERRM返回的是User-Defined Exception

一个Oracle的错误消息最多只能包含512个字节的错误代码。如果没有异常被触发,则SQLCODE返回0SQLERRM返回“ORA-0000normal, suclearcase/" target="_blank" >ccessful completion”。


原文转自:http://www.ltesting.net