美文网首页
异常处理(Oracle学习)

异常处理(Oracle学习)

作者: weiyu_you | 来源:发表于2018-09-20 00:29 被阅读0次

七岁那年,我抓到一只蝉;就以为能抓住整个夏天

异常处理:就是当发现异常出现,则捕获提示

预定义的 Oracle 异常,有异常名,有错误代码,有异常信息。
非预定义的 Oracle 异常,有错误代码,有异常信息,但是没有异常名字。

在实际开发中,我们的异常处理,一般情况下都是需要使用 Java 代码方式来处理。因为我们学习的 Java 语言是面向对象的

  1. Oracle 数据库其实是一个关系型数据库,如果要操作的话,太麻烦了。

  2. C 面向过程:步骤需要详细到每一步,所有的资源释放都要自己来。

  3. Java 面向对象:所有的业务逻辑,交给对应的对象去执行。

     declare
            vid int;
            vname varchar(2);  
     begin
            select id, name into vid, vname from     tb_stuu;
        dbms_output.put_line('vid 的值:' || vid );
        dbms_output.put_line('vname 的值:' || vname );
    
    exception
        when too_many_rows then
             dbms_output.put_line('如果有太多数据返回');
        when no_data_found then
             dbms_output.put_line('找不到对应的数据');
        when others then
             dbms_output.put_line('其实我也懵的..愿主保佑你');
     end;
    

自定义异常

 declare
   myexcption exception;
begin
   dbms_output.put_line('------ 前 ------');
   -- 制造一个异常
   raise myexcption;
   dbms_output.put_line('------ 后 ------');

实现异常

 exception 
      when myexcption then 
         dbms_output.put_line('不要紧张,这个是自己做的异常..无毒的');  
      when others then 
         dbms_output.put_line('这个有可能是有毒的哦...');    
end;

一般情况下,我们在开发捕获异常时,需要关系几个点
什么异常?主要根据名字做初步判断。
什么时候报的?看一下,最近有没有哪个模块发生改动,快速定位。
具体信息是什么?根据详细信息推断出问题所在,及时修复。

创建一张表,来收集异常信息

create table tb_error (
       id int primary key,
       errorObject varchar(100),
       errorCode varchar(100),
       errorMsg varchar(200),
       errorDate date
);

创建序列
-- %ROWTYPE:用于给变量赋值对应的类型,
-- 相当于 User user = new User();中给 user 变量赋值的作用

create sequence error_seq;

select * from tb_error;

declare 
   vstuu tb_stuu%ROWTYPE; -- tb_stuu 表的变量
   vmsg varchar(200);   -- 异常信息
   vcode varchar(100); -- 异常编码
begin

如果我们查询一条不存在的记录,则报错

select * into vstuu from tb_stuu where id = 5;
dbms_output.put_line('查询到的名字是:' || vstuu.name);  

 exception
  when others then
    vcode := sqlcode;
    vmsg := sqlerrm;

如果发生异常的话,则需要往 tb_error 表中插入数据

         insert into tb_error(id, errorobject, errorcode, errormsg, errordate)
        values (error_seq.nextval, 'exceptionName', vcode, vmsg, sysdate); 
  
    commit;
end;

相关文章

  • 异常处理(Oracle学习)

    七岁那年,我抓到一只蝉;就以为能抓住整个夏天 异常处理:就是当发现异常出现,则捕获提示 预定义的 Oracle 异...

  • 2018-08-31-Oracle学习第五天

    1、--异常处理(了解) -- 也就是,当发现有异常出现,则捕获提示。 -- 预定义的 Oracle 异常,有异常...

  • ORACLE11-异常处理

    在导出时报错,如下: 可能是由物化视图导致,对FAST方式建立的物化视图存在LOG表,导出前删除该表。DROP M...

  • 11月3日-4期C语言学习总结

    总结:今天学习第九章异常处理,主要学习异常的定义、为什么要异常、怎么自定义异常、异常处理中怎么嵌套TRY块。下午助...

  • 异常处理 ?处理(try-catch) :甩锅(throws)_

    本章概要 本章主要和大家一起学习java异常类的处理机制,深入学习java异常类。掌握异常处理机制,及背后的逻辑。...

  • 210313:clob类型的问题-异常信息处理-将Date日期类

    一. clob类型的问题 Oracle异常处理——ORA-01502:索引或这类索引的分区处于不可用状态 上述问题...

  • 学习python:异常处理

    简介 本文主要介绍python的异常处理机制,包括: 如何使用异常处理 异常的传递 抛出异常 由于比较简单,因此这...

  • 7.28学习 异常处理

    异常的意义 我们程序在开发过程中,总会遇到各种各样的一些问题,有些是由于拼写、配置、选项等等各种引起的程序错误,有...

  • 11.3c#总结

    自定义异常 主要讲从几个方面学习异常处理,了解什么是异常,以及C#的异常处理机制,了解C#常用的异常类,掌握try...

  • 11月3日C#学习总结

    今天学习了异常处理机制,主要就是C#常用的异常类、try、catch和finally关键字处理异常和throw关键...

网友评论

      本文标题:异常处理(Oracle学习)

      本文链接:https://www.haomeiwen.com/subject/mgawnftx.html