作者信息

长期闲置

长风破浪会有时,直挂云帆济沧海。

最近文章
内存条有什么用931
es模块能在node中执行吗597
nodelist是什么意思621
视频教程分类
推荐视频教程
  • php程序员小白到大牛三个月集训php程序员小白到大牛三个月集训
  • Laravel 9 学习正当时—保姆级教程,想学不会都难!Laravel 9 学习正当时—保姆级教程,想学不会都难!
  • 千万级数据并发解决方案(理论+实战)千万级数据并发解决方案(理论+实战)
  • Laravel基础与实战(模块化)Laravel基础与实战(模块化)
  • 首页 >数据库 >Oracle > 正文

    oracle怎么获取过程异常信息

    原创2022-06-10 10:15:37643 关注公众号:每天精选资源文章推送

    在oracle中,可以利用“DBMS_OUTPUT”配合“put_line”打印方法获取存储过程异常信息,语法为“DBMS_OUTPUT.put_line('sqlerrm : ' ||sqlerrm);”;“put_line”打印方法用于换行输出,sqlcode表示异常编号,sqlerrm表示异常的详细信息,并且可以配合substr()方法来截取异常信息。

    本教程操作环境:windows10系统、Oracle 12c版、Dell G3电脑。

    oracle怎么获取过程异常信息

    oracle存储过程异常信息的显示

    之前写存储过程时,异常处理写法是:

    01.png

    这种写法当存储过程抛出异常时,我们不知道其到底抛出了哪种异常(比如列宽度不够大而在插入数据时抛异常),可以按如下方式显示异常信息

    EXCEPTION
    WHEN OTHERS THEN
    DBMS_OUTPUT.put_line('sqlcode : ' ||sqlcode);
    DBMS_OUTPUT.put_line('sqlerrm : ' ||sqlerrm);
    ROLLBACK;
    END ...

    sqlcode是异常编号,sqlerrm是异常的详细信息,如果异常信息太多,可以截取一段显示,如

    DBMS_OUTPUT.put_line('sqlerrm : ' ||substr(sqlerrm,1,100));

    是截取前100个字符显示出来。

    推荐教程:《Oracle视频教程

    以上就是oracle怎么获取过程异常信息的详细内容,更多请关注php中文网其它相关文章!

    20期PHP线上班

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

  • 相关标签:oracle
  • 推荐:PHP从基础到实战教程视频

    相关文章

    相关视频


    专题推荐