Avoid Recursive Trigger Calls In Salesforce
Recursion occurs when same code is executed again and again. It can lead to infinite loop and which can result to governor limit sometime. Sometime it can also result in unexpected output or the error “maximum trigger depth exceeded”. So, we should write code in such a way that it does not result to recursion.
For example, I’ve a trigger on Account object, which will be execute on before Update and after Update. In after Update I’ve some custom logic to update Account records. So, when I’m updating the Account records in After Update, it is throwing error “maximum trigger depth exceeded”. So, it is a recursion in apex trigger.
To avoid the situation of recursive call, we have to write code in such a way that the trigger will execute one time. To do so, we can create a class with a static Boolean variable with default value true. In the trigger, before executing the code keep a check that the variable is true or not.
Here in below trigger, I want to execute both before and after Update trigger only one time. I’m checking the static Boolean variable is true in both before and after Update trigger. In after update trigger changed the variable to false and after updating the account records, again changed the variable to true. In this way you can handle bulk of records in recursive trigger.
Apex Class:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | public Class AccountTriggerHelper{ //Trigger execution check variable public static Boolean runOnce = true ; //On before update public void onBeforeUpdate(map<Id, Account> mapNewAccount, map<Id, Account> mapOldAccount){ //Write your logic here System.debug( 'Is Before Update' ); } //On after update public void onAfterUpdate(map<Id, Account> mapNewAccount, map<Id, Account> mapOldAccount){ Update [SELECT Id, Name FROM Account WHERE Id IN: mapNewAccount.keyset()]; AccountTriggerHelper.runOnce = true ; System.debug( 'Is After Update' ); } } |
Apex Trigger:
1 2 3 4 5 6 7 8 9 10 11 12 13 | trigger AccountTrigger on Account(before Update, after Update) { AccountTriggerHelper helper = new AccountTriggerHelper(); if (Trigger.isBefore && Trigger.isUpdate && AccountTriggerHelper.runOnce){ helper.onBeforeUpdate(Trigger.newMap, Trigger.OldMap); } if (Trigger.isAfter && Trigger.isUpdate && AccountTriggerHelper.runOnce){ AccountTriggerHelper.runOnce = false ; helper.onAfterUpdate(Trigger.newMap, Trigger.OldMap); } } |
Debug Log:
Comments
Post a Comment