要保證不中斷,需要用游標(biāo),單個(gè)記錄進(jìn)行插入,異常記錄插入錯(cuò)誤信息表
創(chuàng)新互聯(lián)專注于武川網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供武川營(yíng)銷型網(wǎng)站建設(shè),武川網(wǎng)站制作、武川網(wǎng)頁(yè)設(shè)計(jì)、武川網(wǎng)站官網(wǎng)定制、重慶小程序開發(fā)服務(wù),打造武川網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供武川網(wǎng)站排名全網(wǎng)營(yíng)銷落地服務(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沒有定義,而p1中 exp1進(jìn)行過初始化, 所以p1認(rèn)識(shí)exp1,erp2不認(rèn)識(shí)(將其當(dāng)做其它)
你可以給exp1定義一個(gè)異常號(hào)碼,這樣在p2中截獲異常時(shí)通過對(duì)異常號(hào)碼進(jìn)行判斷。
或者把他們放到一個(gè)oracle包中,將exp1 定義為 包變量,這樣p1中初始化過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)
);
--------在過程的例外里向跟蹤表寫入錯(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ǔ)過程出的異常吧,那就是說只有執(zhí)行一次這個(gè)存儲(chǔ)過程才會(huì)拋一次異常么?如果這樣我建議你可以再寫個(gè)存儲(chǔ)過程來(lái)調(diào)用你這個(gè)存儲(chǔ)過程,這樣來(lái)記錄異常的次數(shù)。然后再進(jìn)行處理!