如何在触发器中处理异常

时间:2019-01-10 08:03:53

标签: oracle plsql exception-handling database-trigger

我想在触发器中添加异常处理。

我如下创建了触发器。

我想在其中添加异常处理。这样,如果有任何无效条件,我的触发器就不会失败。

CREATE OR REPLACE TRIGGER system_notification_audit
 AFTER 
      INSERT OR 
      UPDATE 
on system_notification
FOR EACH ROW
    begin
insert into system_notification_log 
select :NEW.ID , :NEW.NAME, :NEW.Description, :NEW.PREFERENCE, :NEW.FREQUENCY, 
       :NEW.IS_HIGH, :NEW.IS_REQUIRED, :NEW.UPDATED_BY, :NEW.UPDATED_DATE
  from dual
 where :OLD.PREFERENCE <> :NEW.PREFERENCE 
 OR :OLD.FREQUENCY <> :NEW.FREQUENCY OR :NEW.IS_HIGH <> :OLD.IS_HIGH OR :NEW.IS_REQUIRED <> :OLD.IS_REQUIRED;
END;

1 个答案:

答案 0 :(得分:1)

仅忽略异常并非总是设计程序的好方法。至少将错误记录在某处,以便以后观察。

请注意,您的INSERT语句可以使用简单的insert(无select)和IF条件来重写。

CREATE OR REPLACE TRIGGER system_notification_audit AFTER
     INSERT OR UPDATE ON system_notification
     FOR EACH ROW
BEGIN
     IF
          :old.preference    <>:new.preference OR :old.frequency <>:new.frequency 
             OR :new.is_high <>:old.is_high OR :new.is_required  <>:old.is_required
     THEN
          INSERT INTO system_notification_log (
               id,
               name,
               description,
               preference,
               frequency,
               is_high,
               is_required,
               updated_by,
               updated_date
          ) VALUES (
               :new.id,
               :new.name,
               :new.description,
               :new.preference,
               :new.frequency,
               :new.is_high,
               :new.is_required,
               :new.updated_by,
               :new.updated_date
          );
     END IF;

 EXCEPTION WHEN OTHERS THEN
  pr_trigger_logs(trig_name => 'system_notification_audit',
                    err_msg => DBMS_UTILITY.FORMAT_ERROR_BACKTRACE()); 
    -- calling an error logging procedure.
END;
/

我不会为您提供过程pr_trigger_logs的定义。作为练习,我让您提出!!