要保證不中斷,需要用游標(biāo),單個(gè)記錄進(jìn)行插入,異常記錄插入錯(cuò)誤信息表
創(chuàng)新互聯(lián)專(zhuān)注于武川網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供武川營(yíng)銷(xiāo)型網(wǎng)站建設(shè),武川網(wǎng)站制作、武川網(wǎng)頁(yè)設(shè)計(jì)、武川網(wǎng)站官網(wǎng)定制、重慶小程序開(kāi)發(fā)服務(wù),打造武川網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供武川網(wǎng)站排名全網(wǎng)營(yíng)銷(xiāo)落地服務(wù)。
declare
begin
for rec in (select * from b) loop
begin
insert into a
select * from b where ...;
exception when otherst then
insert into err_msg
select * from b where ...;
end;
end loop;
end;
很顯然在p2中 異常exp1沒(méi)有定義,而p1中 exp1進(jìn)行過(guò)初始化, 所以p1認(rèn)識(shí)exp1,erp2不認(rèn)識(shí)(將其當(dāng)做其它)
你可以給exp1定義一個(gè)異常號(hào)碼,這樣在p2中截獲異常時(shí)通過(guò)對(duì)異常號(hào)碼進(jìn)行判斷。
或者把他們放到一個(gè)oracle包中,將exp1 定義為 包變量,這樣p1中初始化過(guò)exp1,p2中也可以使用了。
先建一個(gè)錯(cuò)誤跟蹤表
create sequence s_error_id;
CREATE TABLE ERROR_RECORD
(
ERROR_ID NUMBER(10) primary key,
ERROR_CODE NUMBER(10),
ERROR_MSG VARCHAR2(2000),
ERROR_DATE DATE,
ERROR_PROGRAM VARCHAR2(200)
);
--------在過(guò)程的例外里向跟蹤表寫(xiě)入錯(cuò)誤信息:
create or replace procedure day_task is
v_sqlcode ERROR_RECORD.ERROR_CODE%type;
v_msg ERROR_RECORD.error_msg%type;
begin
------program body
exception when others then
--記錄錯(cuò)誤信息表
v_sqlcode :=sqlcode;
v_msg :=sqlerrm;
insert into error_record(error_code,error_msg,error_date,error_program)
values (v_sqlcode,v_msg,sysdate,‘day_task’);
end;
異常是執(zhí)行這個(gè)存儲(chǔ)過(guò)程出的異常吧,那就是說(shuō)只有執(zhí)行一次這個(gè)存儲(chǔ)過(guò)程才會(huì)拋一次異常么?如果這樣我建議你可以再寫(xiě)個(gè)存儲(chǔ)過(guò)程來(lái)調(diào)用你這個(gè)存儲(chǔ)過(guò)程,這樣來(lái)記錄異常的次數(shù)。然后再進(jìn)行處理!
新聞名稱(chēng):oracle如何寫(xiě)異常處理,Oracle異常
標(biāo)題網(wǎng)址:http://jinyejixie.com/article36/hsejpg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、做網(wǎng)站、服務(wù)器托管、網(wǎng)站排名、面包屑導(dǎo)航、外貿(mào)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)