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.