Проблема в триггере обновления в Oracle

У меня есть триггер ниже для отправки электронной почты всякий раз, когда есть обновление столбца ANALYZED_BY в моей таблице cust_bug_data. Проблема, с которой я столкнулся, заключается в том, что триггер отправляет электронное письмо, даже если в cust_bug_data обновлены другие столбцы.

Допустим, мой cust_bug_data похож на "создать таблицу cust_bug_data (число producd_id, тема varchar (10), ANALYZED_BY varchar2 (1))"

Мое требование ниже: триггер должен выполняться всякий раз, когда происходит обновление значения столбца ANALYZED_BY, а для обновления значения других столбцов оно не должно выполняться.

==========================================================================

create table cust_bug_data(producd_id number, subject varchar(10), ANALYZED_BY varchar2(1))
--Below is the trigger
create or replace TRIGGER CUST_BUG_SEND_ASSIGNMENT_EMAIL
  after UPDATE of ANALYZED_BY ON cust_bug_data
  for each row

  DECLARE
  email_id_val varchar2(50);
  l_plain CLOB;
  l_html CLOB;
  cust_bug_number number;
  bug_subject varchar2(100);
  current_user_email varchar2(100);
  BEGIN
 THEN

  CASE
  WHEN UPDATING('ANALYZED_BY') THEN
  IF :NEW.ANALYZED_BY is not null THEN

  --Get email of receiver
  SELECT EMAIL_ID into email_id_val FROM  CUST_BUG_USER_MGR_RLTN where GUID = :NEW.ANALYZED_BY;

  --Get email of sender
   current_user_email := APEX_CUSTOM_AUTH.GET_USER;

   wwv_flow_api.set_security_group_id;
  dbms_lob.createTemporary(l_plain,true);
  dbms_lob.createTemporary(l_html,true);
  dbms_lob.append(l_plain,'New Bugs Generated'||utl_tcp.crlf);
  dbms_lob.append(l_plain,''||utl_tcp.crlf||utl_tcp.crlf);

  dbms_lob.append(l_plain,:new.bug_number||utl_tcp.crlf);
  dbms_lob.append(l_html,'<tr><td><a href="https://bug.oraclecorp.com/pls/bug/webbug_print.show?c_rptno='||:new.bug_number||'">'||:new.bug_number||'</a>'||:new.subject||'</td></tr>'||utl_tcp.crlf);

  dbms_lob.append(l_html,utl_tcp.crlf||'</table>');
   apex_mail.send(
    p_to => email_id_val,
    p_from => current_user_email,
    p_subj => 'Action Required: New customer bugs to be Analyzed in Bug Insight',
    p_body => l_plain,
    p_body_html => l_html
                  );

  dbms_lob.freeTemporary(l_plain);
  dbms_lob.freeTemporary(l_html);
  END IF;
  END CASE;
  END;

person Subhash Tiwari    schedule 17.04.2020    source источник


Ответы (1)


Вы можете изменить свой код триггера следующим образом:

create table cust_bug_data(producd_id number, subject varchar(10), ANALYZED_BY varchar2(1))
--Below is the trigger
create or replace TRIGGER CUST_BUG_SEND_ASSIGNMENT_EMAIL
  after UPDATE of ANALYZED_BY ON cust_bug_data
  for each row
  when ((NEW.ANALYZED_BY <> OLD.ANALYZED_BY OR OLD.ANALYZED_BY IS NULL) 
         AND NEW.ANALYZED_BY is not null) -- added this condition
  DECLARE
  email_id_val varchar2(50);
  l_plain CLOB;
  l_html CLOB;
  cust_bug_number number;
  bug_subject varchar2(100);
  current_user_email varchar2(100);
  BEGIN
  --THEN

  --CASE
  --WHEN UPDATING('ANALYZED_BY') THEN
  --IF :NEW.ANALYZED_BY is not null THEN -- removed 4 lines 
  --Get email of receiver
  SELECT EMAIL_ID into email_id_val FROM  CUST_BUG_USER_MGR_RLTN where GUID = :NEW.ANALYZED_BY;

  --Get email of sender
   current_user_email := APEX_CUSTOM_AUTH.GET_USER;

   wwv_flow_api.set_security_group_id;
  dbms_lob.createTemporary(l_plain,true);
  dbms_lob.createTemporary(l_html,true);
  dbms_lob.append(l_plain,'New Bugs Generated'||utl_tcp.crlf);
  dbms_lob.append(l_plain,''||utl_tcp.crlf||utl_tcp.crlf);

  dbms_lob.append(l_plain,:new.bug_number||utl_tcp.crlf);
  dbms_lob.append(l_html,'<tr><td><a href="https://bug.oraclecorp.com/pls/bug/webbug_print.show?c_rptno='||:new.bug_number||'">'||:new.bug_number||'</a>'||:new.subject||'</td></tr>'||utl_tcp.crlf);

  dbms_lob.append(l_html,utl_tcp.crlf||'</table>');
   apex_mail.send(
    p_to => email_id_val,
    p_from => current_user_email,
    p_subj => 'Action Required: New customer bugs to be Analyzed in Bug Insight',
    p_body => l_plain,
    p_body_html => l_html
                  );
  --END IF;
  --END CASE; -- removed this two
  dbms_lob.freeTemporary(l_plain);
  dbms_lob.freeTemporary(l_html);

  END;
person Popeye    schedule 17.04.2020