oracle的异常

– 异常处理(了解)

– 也就是,当发现有异常出现,则捕获提示。
– 预定义的 Oracle 异常,有异常名,有错误代码,有异常信息。
– 非预定义的 Oracle 异常,有错误代码,有异常信息,但是没有异常名字。

– 在实际开发中,我们的异常处理,一般情况下都是需要使用 Java 代码方式来处理。

– 因为我们学习的 Java 语言是面向对象的
– Oracle 数据库其实是一个关系型数据库,如果要操作的话,太麻烦了。
– C 面向过程:步骤需要详细到每一步,所有的资源释放都要自己来。
– Java 面向对象:所有的业务逻辑,交给对应的对象去执行。

select * from tb_stuu;

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;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值