zoukankan      html  css  js  c++  java
  • ORACLE 存储过程异常捕获并抛出

     for tab_name in tables loop  
    execute immediate 'drop table '||tab_name;  --此处可能会报错
     end loop;

    当前情况是,循环表,进行删除,如果出现表不存在,则会异常中断,导致整个存储过程挂掉,需求是要能跳过错误的执行,不进行处理,进行下个循环。

    最终代码:

     for tab_name in tables loop  
    begin
    
    execute immediate 'drop table '||tab_name;  --此处可能会报错
    
     EXCEPTION WHEN others THEN NULL;
    end;
    
     end loop;

    如何抛出

    上面存储过程是,异常处理写法是(异常跳过不处理): 
    
    EXCEPTION 
    WHEN OTHERS THEN 
    END
    
    这种写法当存储过程抛出异常时,我们不知道其到底抛出了哪种异常(比如列宽度不够大而在插入数据时抛异常),可以按如下方式显示异常信息 
    
    EXCEPTION 
    WHEN OTHERS THEN 
    DBMS_OUTPUT.put_line(‘sqlcode : ’ ||sqlcode); 
    DBMS_OUTPUT.put_line(‘sqlerrm : ’ ||sqlerrm); 
    END
    
    sqlcode是异常编号,sqlerrm是异常的详细信息,如果异常信息太多,可以截取一段显示,如 
    DBMS_OUTPUT.put_line(‘sqlerrm : ’ ||substr(sqlerrm,1,100));是截取前100个字符显示出来。
    也可以插入到日志表
    insert xxx  values (sqlcode,sqlerrm)
    

      

  • 相关阅读:
    Vue.js 学习报告
    Javascript 巩固:阮一峰javascript教程 (2017-1-17)
    2017-1-17
    my-Life项目开发流程-02
    《Javascript 权威指南 第六版》
    2017-1-11
    2017-1-10
    2017-1-9
    前端知识解惑: 响应式 兼容性 不错的知识链接
    2017-1-3
  • 原文地址:https://www.cnblogs.com/wdw31210/p/7009731.html
Copyright © 2011-2022 走看看