异常处理(Oracle学习)

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

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

预定义的 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;
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容