在Oracle中,内置了数据操作的返回码sqlcode,来存储最近一次SQL语句执行的状态码,其返回的是一个整数值,用于判断SQL语句的执行结果。例如返回0表示成功;-1表示失败。sqlcode不能直接在SQL语句中使用,必须先将其赋给变量后,才能在sql语句中使用。
exception
when others then
p_error_no := 101;
p_error_info :='执行存储过程错误'||'AP_FUUSERPUB_SERIALNO_GET';
p_error_id := SQLCODE;
p_error_sysinfo := SQLERRM;
因为错误码仅做展示以及定位问题使用,所以在LightDB中执行后就不能用Oracle的内置错误码,应该使用LightDB内置的错误码来代替。
在LightDB中,我们可以使用sqlstate来代替sqlcode,这样问题又出现了,LightDB中的sqlstate是一个5位长度的字符串(从00000~ZZZZZ),而Oracle的sqlcode是整型的,所以在类型上也不兼容,还是得需要业务改代码,所以针对这种情况,LightDB在23.2版本开始,要完全支持sqlcode。效果如下:
其中sqlcode为sqlstate的转码前状态,这样问题也来了,用户拿到sqlcode为16777248时,并不知道这是什么意思,所以我们也提供了转换函数sqlcode_to_sqlstate,效果如下:
用户会得到一个错误码P0001,这时用户可以到LightDB官网找到对应的错误码,即可了解报错内容。地址如下:
http://www.light-pg.com/docs/lightdb/current/errcodes-appendix.html
官网找到刚才错误码P0001,为raise异常。
.