如何处理异常并执行剩余的语句?

时间:2013-06-28 07:42:22

标签: oracle plsql oracle11g oracle10g plsqldeveloper

请找到以下区块。

for i in 1..acd.count loop

insert into customer_account_mapping select customerid,upper(pcd(i)),upper(acd(i)),cost from customer_master where customername=customer_name and concat(upper(pcd(i)),upper(acd(i))) not in (select concat(upper(pcode),upper(acode)) from customer_account_mapping);

insert into user_permissions select distinct user_id,sales_person_name,sales_mgr_name,upper(pcd(i)),upper(acd(i)) from user_permissions where sales_person_name=sales_person and concat(upper(pcd(i)),upper(acd(i))) not in (select concat(upper(pcode),upper(acode)) from user_permissions) and rownum<2 ;
commit;
end loop;

如果第一个insert语句中发生错误,如何处理它并执行第二个insert语句。

2 个答案:

答案 0 :(得分:2)

begin ... end ... exception包裹行,就像try / catch

for i in 1..acd.count loop

begin 
   insert into customer_account_mapping select customerid,upper(pcd(i)),upper(acd(i)),cost from customer_master where customername=customer_name and concat(upper(pcd(i)),upper(acd(i))) not in (select concat(upper(pcode),upper(acode)) from customer_account_mapping);
exception when others then 
   -- handle the exception
end;

insert into user_permissions select distinct user_id,sales_person_name,sales_mgr_name,upper(pcd(i)),upper(acd(i)) from user_permissions where sales_person_name=sales_person and concat(upper(pcd(i)),upper(acd(i))) not in (select concat(upper(pcode),upper(acode)) from user_permissions) and rownum<2 ;
commit;
end loop;

答案 1 :(得分:0)

EXCEPTION  -- exception handlers begin



 WHEN exception type  -- handles 'division by zero' error
           ...

 WHEN OTHERS THEN  -- handles all other errors
      ROLLBACK;

END;

在第一个插入语句后放置此代码块。