异常处理
健壮的语言就的有异常捕捉与处理机制。
还是先看下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>