异常处理

异常处理
健壮的语言就的有异常捕捉与处理机制。
还是先看下Java里的异常捕捉:
Try{

}Catch(Exception e){

}
在Oracle中要这样做:

EXCEPTION
WHEN OTHERS THEN

这里的OTHERS和Exception的意思是一样的,表示捕捉所有的异常。
这意味着我们也可已捕捉指定的异常。
在Oracle里的异常只有少数常见的有自己的名字,我们可以把OTHERS换成相应异常的名字来捕获。剩下的Oracle只是给分配了一个错误码是一个负数比如:-1843代表一个日期错误。
那么我们只能这样来捕获了:
EXCEPTION
WHEN OTHERS THEN
IF SQLCODE =-1843 THEN

ELSIF … THEN

END IF;
为了我们了解异常的详细信息,Oracle给了我们两个异常函数,SQLCODE和SQLERRM。确切的说不应该叫函数。他们两个分别包含了发生的异常的错误码和错误描述信息(当然是Oracle提供的描述),所以应该叫作系统变量才对。
抛出自定义的异常
一、 使用RAISE语句
使用RAISE前我们需要在DELCARE中定义我们的异常。
PRAGMA EXCEPTION_INIT(异常名称,错误码);
然后在BEGIN END;里就可以使用RAISE 异常名称来抛出了。
二、 使用RAISE_APPLICATION_ERROR函数来抛出
RAISE_APPLICATION_ERROR(错误码,错误描述);
注重RAISE_APPLICATION_ERROR只能在过程、函数、包、触发器中使用。

<script type="text/javascript"> </script> <script src="http://pagead2.googlesyndication.com/pagead/show_ads.js" type="text/javascript"></script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值