在 Before 事件中实现此代码的所有功能



我将如何在 before 事件中实现此代码的所有功能,无论是重新育级、更新、插入还是其他任何内容。所以,这是在每种情况下都能正常工作的代码,但如果我想在 Before 事件中做所有相同的事情怎么办。 谢谢

//Trigger
trigger InvoiceProductTrigger on Invoice_Product__c (before insert, before update, after insert, after update, after delete) {
if((Trigger.isInsert || Trigger.isUpdate) && Trigger.isBefore){
InvoiceClass.invoiceProduct(Trigger.new);
}
if(Trigger.isAfter && (Trigger.isInsert || Trigger.isUpdate)){
InvoiceClass.invoiceAmountUpdate(Trigger.new);
} 
if(Trigger.isAfter && Trigger.isDelete){
InvoiceClass.invoiceAmountUpdate(Trigger.old);
}
if(Trigger.isAfter && Trigger.isUpdate){
InvoiceClass.invoiceAmountUpdate(Trigger.old);
}
}
//Handler class
public class InvoiceClass {
public static void invoiceProduct(List<Invoice_Product__c> invProduct){
for(Invoice_Product__c inv : invProduct){
inv.Total_Price__c = inv.Price__c * inv.Quantity__c;
}
}
public static void invoiceAmountUpdate(List<Invoice_Product__c> invProduct ){
Set<id> invoiceIds = new Set<id>();
for(Invoice_Product__c invPro : invProduct){
if(invPro.InvoiceLookUp__c != Null){
invoiceIds.add(invPro.InvoiceLookUp__c);   
}
}
List<Invoice__c> invoices = [Select id, Total_Amount__c, (Select id, Total_Price__c
From Invoice_Products__r)
From Invoice__c where id in : invoiceIds];
for(Invoice__c inv: invoices){
inv.Total_Amount__c = 0;
for(Invoice_Product__c invProd : inv.Invoice_Products__r){
inv.Total_Amount__c += invProd.Total_Price__c;
}
}
if(invoices != Null){
update invoices;
}
}
}

您不能纯粹在before事件中实现汇总触发器 - 至少,不容易,并且不清楚为什么要这样做。无法从Invoice_Product__cbefore insertbefore update触发器查询Invoice_Product__c记录,因为它们尚未提交到数据库。

请考虑使用声明性查找汇总摘要来定义汇总,而不是从头开始编写汇总触发器。

最新更新