oracle 異常處理 exception
在實際開發plsql中,我們常常會將異常的資訊保留到日記表中,以備以後檢查時使用,這樣我們就可以使用sqlcode 和sqlerm 函式來記錄異常和區分異常。但是要注意:sqlcode和sqlerrm不可以直接在sql語句中使用,必須將它賦值給一個區域性變數。
create table err_log(name varchar2(100),err_code number(10),err_message
varchar2(100),occur_date date);
--no_data_found和too_many_rows是經常發生的異常,所以對於plsql寫這樣的異常捕獲是很好的
--系統預定義異常
declare
a testerr%rowtype;--define a variable
--define error message
v_err_code err_log.err_code%type;
v_err_message err_log.err_message%type;
vname err_log.name%type;
begin
select * into a from testerr where name='test';
--start trap exception
exception
when others then
--必須要將sqlcode和sqlerr賦值給變數,不可以直接在sql語句中使用
vname:='select * into a from testerr where name=''test''; this statement,a type
is testerr%rowtype';
v_err_code:=sqlcode;
v_err_message:=sqlerrm;
insert into err_log values(vname,v_err_code,v_err_message,sysdate);
end;
/
varchar2(100),occur_date date);
--no_data_found和too_many_rows是經常發生的異常,所以對於plsql寫這樣的異常捕獲是很好的
--系統預定義異常
declare
a testerr%rowtype;--define a variable
--define error message
v_err_code err_log.err_code%type;
v_err_message err_log.err_message%type;
vname err_log.name%type;
begin
select * into a from testerr where name='test';
--start trap exception
exception
when others then
--必須要將sqlcode和sqlerr賦值給變數,不可以直接在sql語句中使用
vname:='select * into a from testerr where name=''test''; this statement,a type
is testerr%rowtype';
v_err_code:=sqlcode;
v_err_message:=sqlerrm;
insert into err_log values(vname,v_err_code,v_err_message,sysdate);
end;
/
自定義異常:
Error_number:使用者指定的異常數字,範圍是-20000 到-20999。
Message:使用者指定的異常資訊,字元最大長度為2048 個位元組。
True|false:可選引數,true表示放到先前異常的stack中,預設為false,替換先前的所
有異常。
例子:
Message:使用者指定的異常資訊,字元最大長度為2048 個位元組。
True|false:可選引數,true表示放到先前異常的stack中,預設為false,替換先前的所
有異常。
例子:
/**
raise_application_error
**/
declare
--define user-define exception
invalidate_classes_err exception;
pragma exception_init(invalidate_classes_err,-20029);
--start execute field
begin
update classes set name='aa'where id=10000;
--raise exception
if sql%notfound then
raise_application_error(-20029,'invalidate id=10000!');
end if;
commit;
--start trap exception
exception
when invalidate_classes_err then
dbms_output.put_line('no such id is 10000.'||sqlcode||':'||sqlerrm);
end;
這裡使用了非預定義的異常,sqlcode 和sqlerrm 和raise_applicatition_error 的number 和
message保持一直,這樣可以捕獲異常,做相關操作。
raise_application_error
**/
declare
--define user-define exception
invalidate_classes_err exception;
pragma exception_init(invalidate_classes_err,-20029);
--start execute field
begin
update classes set name='aa'where id=10000;
--raise exception
if sql%notfound then
raise_application_error(-20029,'invalidate id=10000!');
end if;
commit;
--start trap exception
exception
when invalidate_classes_err then
dbms_output.put_line('no such id is 10000.'||sqlcode||':'||sqlerrm);
end;
這裡使用了非預定義的異常,sqlcode 和sqlerrm 和raise_applicatition_error 的number 和
message保持一直,這樣可以捕獲異常,做相關操作。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22392018/viewspace-711833/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- PHP基礎:異常處理ExceptionPHPException
- 甩鍋(throws)_ java異常(Exception)處理JavaException
- NETCORE - 全域性異常處理(Exception)NetCoreException
- oracle異常處理Oracle
- Oracle 處理異常Oracle
- oracle 使用異常exceptionOracleException
- 【轉】Oracle 異常處理Oracle
- Spring Cloud Gateway自定義異常處理Exception HandlerSpringCloudGatewayException
- Oracle 監聽異常處理Oracle
- Oracle異常錯誤處理Oracle
- ORACLE 異常錯誤處理Oracle
- 異常(Exception)Exception
- 異常篇——異常處理
- oracle常見異常等待——latch處理思路Oracle
- 異常處理
- Sanic Exception – 異常Exception
- Oracle開發基礎-異常處理Oracle
- 解析Oracle developer 異常處理機制OracleDeveloper
- ORACLE RAC spfile異常處理辦法Oracle
- 異常-throws的方式處理異常
- 異常處理與異常函式函式
- JavaScript 異常處理JavaScript
- ThinkPHP 異常處理PHP
- React 異常處理React
- 08、異常處理
- JAVA 異常處理Java
- JAVA異常處理Java
- Abp 異常處理
- PowerShell 異常處理
- plsql異常處理SQL
- Swift 異常處理Swift
- JS異常處理JS
- app異常處理APP
- MySQL異常處理MySql
- 異常處理 (轉)
- golang - 異常處理Golang
- 異常處理2
- 異常處理1