Description:
Many developers face this issue because of a recursive trigger. For example,
in an 'after update' trigger, a developer could be performing an update
operation and this would lead to recursive call, and the error:
"maximum trigger depth exceeded"
Resolution:
In order to avoid the situation of recursive call, make sure your trigger
is getting executed only one time. To do so, you can create a class with a
static set<string> variable .
In the trigger, before executing your code keep a check that the string contains
trigger or not.based on that it will execute only once.
Below same code we will add where ever recursion happen.
public with sharing class RecursiveCheck {
public static Set<String> triggerMonitor = new Set<String>();
}
trigger ContactTrigger on Contact (after insert) {
if(trigger.isInsert && !RecursiveCheck.triggerMonitor.contains('NAV_CRM_ContactTrigger')){
RecursiveCheck.triggerMonitor.add('NAV_CRM_ContactTrigger');
====your logic here====
}
}
where ever your doing DML in class just need to add below line, it will stop recursion.
if(updContacts.size() > 0){
RecursiveCheck.triggerMonitor.add('ContactTrigger'); //Here we need to add trigger name.
database.update(updContacts);
}
Recursive Triggers |