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();
}