Salesforce Apex 觸發器學習記錄

Apex 觸發器(Apex Triggers)是一種特殊的 Apex 類。它的主要作用是在一條記錄被插入、修改、刪除之前或之後自動執行一系列的操作。每一個 Trigger 類必須對應一種對象。
1、直接在Trigger中寫對應的邏輯。
2、通過Trigger 綁定 TriggerHandler ,在TriggerHandler中寫對應的業務邏輯
注:在處理Trigger中的業務邏輯時,一定要考慮執行順序和DML操作
參考:https://developer.salesforce.com/docs/atlas.en-us.apexcode.meta/apexcode/apex_triggers_order_of_execution.htm?search_text=Trigger

  • Trigger 觸發事件:
    before insert:插入數據之前
    before update:更新數據之前
    before delete:刪除數據之前
    after insert:插入數據之後
    after update:更新數據之後
    after delete:刪除數據之後
    after undelete:恢復數據之後
  • Trigger 常用執行事件:
    isInsert:是否是 insert 操作
    isUpdate:是否是 update 操作
    isDelete:是否是 delete 操作
    isBefore:是否是操作之前
    isAfter:是否是操作之後

Trigger
代碼目錄:在triggers文件夾下
在這裏插入圖片描述
語法結構:

/**
 * AccountTriggers  類名,自定義
 * Account 爲Account 對象創建trigger  on後面爲對象名稱
 * 參數:事件類型,如刪除前action   插入前action 等
 *      如果業務寫了對應action  ,在參數中沒有對應參數   ,後面業務邏輯也不會執行
 */
trigger AccountTriggers on Account(before delete, before insert, before update, 
                                    after delete, after insert, after update) {
	if (Trigger.isBefore) {
		// 事件前 處理的邏輯
		if (Trigger.isDelete) {
			//刪除Account前邏輯
		}
		if(Trigger.isUpdate){
			// 更新前處理的邏輯
			// Trigger.new 可以獲取到處理操作後的List<Account>
			List<Account> list_new_account = Trigger.new;
			// 獲取修改之前的數據集
			List<Acclout> list_old_account = Trigger.old;
			// 返回對應原來數據的Map
			Map<Id,Contact> map_new_account = Trigger.newMap;
			// 返回對應新數據的Map
			Map<Id,Contact> map_old_account = Trigger.oldMap;
			
		}
		// ... 
	}else{
		// 事件後處理的邏輯
		// ... 事件處理同上
	}                                    
}

TriggerHandler
業務代碼目錄:在classe文件夾下,實質是一個Apex類
代碼結構(Handler Class):

/**
 * Triggers 源碼
 * 本質是通過bind方法將對應的action和hanler 綁定對應的事件類型
 * 然後通過manage 方法執行對應的業務邏輯
 */
public class Triggers {
    /**
     * Enum representing each of before/after CRUD events on Sobjects
    */
    public enum Evt {
        afterdelete, afterinsert, afterundelete,
        afterupdate, beforedelete, beforeinsert, beforeupdate   
    }
    /**
     *  Simplistic handler to implement on any of the event. It doesn't requires or enforces any patter except the
     *  method name to be "handle()", a developer is free to use any Trigger context variable or reuse any other
     *  apex class here.
    */
    public interface Handler {
        void handle();          
    } 
    // Internal mapping of handlers
    Map<String, List<Handler>> eventHandlerMapping = new Map<String, List<Handler>>();
    /**
     *  Core API to bind handlers with events
    */
    public Triggers bind(Evt event, Handler eh) {
        List<Handler> handlers = eventHandlerMapping.get(event.name());
        if (handlers == null) {
            handlers = new List<Handler>();
            eventHandlerMapping.put(event.name(), handlers);
        }
        handlers.add(eh);
        return this;
    }
    /**
     * Invokes correct handlers as per the context of trigger and available registered handlers
    */
    public void manage() {
        Evt ev = null;
        if(Trigger.isInsert && Trigger.isBefore){
            ev = Evt.beforeinsert;
        } else if(Trigger.isInsert && Trigger.isAfter){
            ev = Evt.afterinsert;
        } else if(Trigger.isUpdate && Trigger.isBefore){
            ev = Evt.beforeupdate;
        } else if(Trigger.isUpdate && Trigger.isAfter){
            ev = Evt.afterupdate;
        } else if(Trigger.isDelete && Trigger.isBefore){
            ev = Evt.beforedelete;
        } else if(Trigger.isDelete && Trigger.isAfter){
            ev = Evt.afterdelete;
        } else if(Trigger.isundelete){
            ev = Evt.afterundelete;             
        }
        List<Handler> handlers = eventHandlerMapping.get(ev.name());
        if (handlers != null && !handlers.isEmpty()) {
            for (Handler h : handlers) {
                h.handle();
            }
        }
    } 
}


/**
 * 必須要實現 Triggers.Handler
 * 重新 handler 方法
 */
public with sharing class AccountHandler implements Triggers.Handler {
	/**
	 * 執行業務邏輯
	 */
	public static void handle(){
		//  業務邏輯
	    System.debug('....');
	    
	    if(Trigger.isInsert){
	    	// xxxxx
	    }
	    
	    if(Trigger.isUpdate){
	    	// xxxxx
	    }
	}
}

/**
 * 在 Trigger 中綁定對應的handler 並執行對應得業務邏輯
 */
 trigger AccoutTrigger on Account(before insert, before update, after insert) {
    new Triggers()
        .bind(Triggers.Evt.afterinsert,new AccountHandler())
        .bind(Triggers.Evt.beforeupdate,new AccountHandler())
        .manage();
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章