Oracle中的sqlerrm和sqlcode

haiross 2019-12-17

Oracle中的sqlerrm和sqlcode

sqlcode:sqlcode函数用来返回pl/sql执行内部异常代码。其中0表示成功;-1表示失败;100表示没有检索到数据;+1表示用户自定义异常。
   语法:sqlcode
sqlerrm:sqlerrm函数用来返回指定错误代码的错误信息。
   语法:SQLERRM [(error_number)]

一个Oracle的错误动静最多只能包孕512个字节的错误代码。
如果没有异常被触发,则SQLCODE返回0,SQLERRM返回“ORA-0000:normal, successful completion”。

如:  SQLCODE=-100  -> SQLERRM=‘no_data_found‘

   SQLCODE=0     -> SQLERRM=‘normal, successfual completion‘


sqlcode和sqlerrm如何使用?
sqlcode和sqlerrm是不能直接在sql语句中使用,必须先将其赋给变量后,才能在sql语句中使用。
例:
    DECLARE
    
    ......

  v_trans_error NUMBER;
   v_trans_error_msg VARCHAR2(512);
  
    BEGIN

  ......

    EXCEPTION

   ......

  WHEN OTHERS THEN
  v_trans_error := SQLCODE;
  v_trans_error_msg := SUBSTR(SQLERRM,1,512);
  DBMS_OUTPUT.PUT_LINE(v_trans_error || ‘---‘ || v_trans_error_msg);

  ......

    END;

相关推荐