Попытка удалить ссылку на ошибку нулевого объекта

В строке 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;    
            }
        }
    }

person Mohd Nabeel    schedule 27.11.2019    source источник
comment
Надо было задать этот вопрос на salesforce.stackexchange.com   -  person Debu Shinobi    schedule 15.09.2020


Ответы (1)


Проблема не в том, что «acct» не инициализирован, это поля «AmountX__c» и «AmountY__c».

Как я вижу, вы запросили максимум 50000 записей, из этих записей некоторые из них имеют значения «Null» для двух вышеуказанных полей.

Я предлагаю проверить, имеют ли два вышеуказанных поля значения «Null» для некоторых записей или нет.

person Aayush Shrivastava    schedule 28.11.2019