Apex - wyzwalacze

Wyzwalacze Apex są jak procedury składowane, które są wykonywane, gdy wystąpi określone zdarzenie. Wyzwalacz jest wykonywany przed i po wystąpieniu zdarzenia w rekordzie.

Składnia

trigger triggerName on ObjectName (trigger_events) { Trigger_code_block }

Wykonywanie wyzwalacza

Poniżej znajdują się zdarzenia, na których możemy uruchomić spust -

  • insert
  • update
  • delete
  • merge
  • upsert
  • undelete

Przykład wyzwalacza 1

Załóżmy, że otrzymaliśmy wymaganie biznesowe, że musimy utworzyć rekord faktury, gdy pole „Status klienta” klienta zmieni się na Aktywne z Nieaktywne. W tym celu utworzymy wyzwalacz na obiekcie APEX_Customer__c, wykonując następujące kroki -

Step 1 - Przejdź do sObject

Step 2 - Kliknij Klient

Step 3 - Kliknij przycisk „Nowy” na liście związanej z wyzwalaczem i dodaj kod wyzwalacza, jak podano poniżej.

// Trigger Code
trigger Customer_After_Insert on APEX_Customer__c (after update) {
   List InvoiceList = new List();
   
   for (APEX_Customer__c objCustomer: Trigger.new) {
      
      if (objCustomer.APEX_Customer_Status__c == 'Active') {
         APEX_Invoice__c objInvoice = new APEX_Invoice__c();
         objInvoice.APEX_Status__c = 'Pending';
         InvoiceList.add(objInvoice);
      }
   }
   
   // DML to insert the Invoice List in SFDC
   insert InvoiceList;
}

Wyjaśnienie

Trigger.new- Jest to zmienna kontekstowa, która przechowuje rekordy aktualnie w kontekście wyzwalacza, w trakcie wstawiania lub aktualizowania. W tym przypadku ta zmienna zawiera zaktualizowane rekordy obiektu Customer.

Istnieją inne zmienne kontekstowe, które są dostępne w kontekście - trigger.old, trigger.newMap, trigger.OldMap.

Przykład wyzwalacza 2

Powyższy wyzwalacz zostanie wykonany, gdy nastąpi operacja aktualizacji w rekordach klienta. Załóżmy, że rekord faktury musi być wstawiony tylko wtedy, gdy Status klienta zmieni się z Nieaktywny na Aktywny, a nie za każdym razem; w tym celu możemy użyć innej zmiennej kontekstowejtrigger.oldMap który zapisze klucz jako identyfikator rekordu, a wartość jako stare wartości rekordu.

// Modified Trigger Code
trigger Customer_After_Insert on APEX_Customer__c (after update) {
   List<apex_invoice__c> InvoiceList = new List<apex_invoice__c>();
   
   for (APEX_Customer__c objCustomer: Trigger.new) {
      
      // condition to check the old value and new value
      if (objCustomer.APEX_Customer_Status__c == 'Active' &&
      
      trigger.oldMap.get(objCustomer.id).APEX_Customer_Status__c == 'Inactive') {
         APEX_Invoice__c objInvoice = new APEX_Invoice__c();
         objInvoice.APEX_Status__c = 'Pending';
         InvoiceList.add(objInvoice);
      }
   }
   
   // DML to insert the Invoice List in SFDC
   insert InvoiceList;
}

Wyjaśnienie

Użyliśmy zmiennej Trigger.oldMap, która, jak wyjaśniono wcześniej, jest zmienną kontekstową, która przechowuje identyfikator i starą wartość aktualizowanych rekordów.