你說的異常是什么意思?如果是,執(zhí)行中的錯誤,那么可以用“調(diào)試”,不過需要有一個系統(tǒng)權(quán)限的擁護才能調(diào)試,權(quán)限好象是什么debug XXXXX。
創(chuàng)新互聯(lián)自2013年創(chuàng)立以來,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務公司,擁有項目成都網(wǎng)站設計、成都網(wǎng)站建設網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元渭源做網(wǎng)站,已為上家服務,為渭源各地企業(yè)和個人服務,聯(lián)系電話:18980820575
如果說的是有時執(zhí)行因為這樣那樣的數(shù)據(jù)問題出現(xiàn)的異常,那么一般都是通過exception來拋出異常的,這樣的拋出的異常,你可以自己編代碼,然后輸入一張表內(nèi),這樣就可以捕獲異常了。如果1表示沒有主鍵,2表示數(shù)據(jù)超長等等。具體的寫法網(wǎng)上很多,這里就不寫了。
如果用自定義異常則可以創(chuàng)建如下代碼
Sql代碼
declare
row_count int;
begin
select count(*) into row_count from tree_table where parent_id = '0001' ;
if (row_count 0) then
RAISE_APPLICATION_ERROR(-20001, '該節(jié)點有子節(jié)點,不能被刪除。');
end if;
select count(*) into row_count from tree_table where id = '0001' and status 1 ;
if (row_count 0) then
RAISE_APPLICATION_ERROR(-20002, '該節(jié)點已被確認,不能被刪除。');
end if;
delete from tree_table where id = '0001';
end;
舉個例子:
create?or?replace?trigger?TRI_Test??before?insert?on?TABLE
for?each?row
declare
e_test?exception;
begin
if?inserting?then
raise?e;
end?if;
end?TRI_Test??;
把子存儲過程中的異常處理去掉,父存儲過程就能捕捉到異常了
當與一個異常錯誤相關(guān)的錯誤出現(xiàn)時,就會隱含觸發(fā)該異常錯誤。用戶定義的異常錯誤是通過顯式使用?RAISE?語句來觸發(fā)。當引發(fā)一個異常錯誤時,控制就轉(zhuǎn)向到?EXCEPTION塊異常錯誤部分,執(zhí)行錯誤處理代碼。
對于這類異常情況的處理,步驟如下:
1、在PL/SQL?塊的定義部分定義異常情況:
異常情況??EXCEPTION;
2、RAISE?異常情況;
3、在PL/SQL?塊的異常情況處理部分對異常情況做出相應的處理。
例:更新指定員工工資,增加100;
DECLARE
v_empno?employees.employee_id%TYPE?:=empno;
no_result??EXCEPTION;
BEGIN
UPDATE?employees?SET?salary?=?salary+100?WHERE?employee_id?=?v_empno;
IF?SQL%NOTFOUND?THEN
RAISE?no_result;
END?IF;
EXCEPTION
WHEN?no_result?THEN?
DBMS_OUTPUT.PUT_LINE('數(shù)據(jù)更新語句失敗了!');
WHEN?OTHERS?THEN
DBMS_OUTPUT.PUT_LINE(SQLCODE||'---'||SQLERRM);
END;
1、彈出錯誤框:
示例代碼:
declare
v_count number;
begin
select count(*) into v_count from dept;
if v_count 10 then
raise_application_error(-20001,'數(shù)量小于10');
end if;
end;
執(zhí)行結(jié)果:
2、控制臺顯示:
示例代碼:
declare
v_count number;
my_exp exception;
begin
select count(*) into v_count from dept;
if v_count 10 then
raise my_exp;
end if;
exception
when my_exp then
dbms_output.put_line('數(shù)量小于10');
when others then
dbms_output.put_line('其他異常');
end;
執(zhí)行結(jié)果:
PS:ORACLE 用戶自定義異常小例子:
CREATE OR REPLACE PROCEDURE test_Exception_byLeejin
(
ParameterA IN varchar,
ParameterB IN varchar,
ErrorCode OUT varchar --返回值,錯誤編碼
)
AS
/*以下是一些變量的定義*/
V NUMBER;
V nvarchar();
V NUMBER;
APP_EXP EXCEPTION; --自定義異常
BEGIN
ErrorCode :='';
IF (ParameterA=ParameterB) THEN
ErrorCode := 'ParameterA = ParameterB';
RAISE APP_EXP; -- 拋出異常
END IF;
EXCEPTION
WHEN APP_EXP THEN --在處理異常
RAISE_APPLICATION_ERROR(-,ErrorCode);
WHEN OTHERS THEN
RAISE_APPLICATION_ERROR(-,'未知異常');
END;
--這個是判斷一個字符串是否為日期型的,如果異常就返回值0
CREATE
OR
REPLACE
FUNCTION
is_date(parameter
VARCHAR2)
RETURN
NUMBER
IS
val
DATE;
BEGIN
val
:=
TO_DATE(NVL(parameter,
'a'),
'yyyy-mm-dd
hh24:mi:ss');
RETURN
1;
EXCEPTION
WHEN
OTHERS
THEN
RETURN
0;
END;
網(wǎng)站題目:oracle怎么拋異常,oracle 拋出異常
當前網(wǎng)址:http://chinadenli.net/article44/dsicihe.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供Google、網(wǎng)站制作、搜索引擎優(yōu)化、商城網(wǎng)站、網(wǎng)站收錄、ChatGPT
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)