LightDB新增对Oracle sqlcode的支持

在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异常。

.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

追魂曲

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值