在acct.AmountX__c += amtX
行和acct.AmountY__c += amtY
行上,这给我一个错误。插入后和更新后,触发器将打开。当我在联系中插入任何记录时,这给我一个错误,我不知道为什么。如果我没记错,为什么要初始化'acct
'?当您尚未初始化某些内容时,就会出现此错误。
public class ContactAccountRollUpAmount {
public static void onAfterInsertOrUpdate(List<Contact> cont){
contAccRollUpAmount(cont);
}
public static void contAccRollUpAmount(List<Contact> contactList){
List<Contact> cont = new List<Contact>([Select AccountId, Amount_Type__c, Amount__c
from Contact
where id in: contactList]);
List<Account> accList = new List<Account>([Select id, AmountX__c, AmountY__c
from Account Limit 50000]);
List<Account> accListToUpdate = new List<Account>();
for(Account acct: accList){
Double amtX = 0;
Double amtY = 0;
system.debug('#########'+acct);
for(Contact con: cont){
if(con.AccountId == acct.Id){
if(con.Amount__c != NULL){
if(con.Amount_Type__c == 'AmountX'){
amtX = amtX + con.Amount__c;
} else if(con.Amount_Type__c == 'AmountY'){
amtY = amtY + con.Amount__c;
}
}
}
}
if(amtX != NULL){
acct.AmountX__c += amtX;
}
if(amtY != NULL){
acct.AmountY__c += amtY;
}
accListToUpdate.add(acct);
}
if(accListToUpdate.size()>0){
update accListToUpdate;
}
}
}
答案 0 :(得分:0)
问题不是'acct
'未初始化,而是字段'AmountX__c'和'AmountY__c'。
正如我所看到的,您查询了最多50000条记录,在这些记录中,其中有一些对于上述两个字段具有'Null'值。
我建议请检查上述两个字段的某些记录是否具有“空”值。