Bulkify Apex Approval.ProcessSubmitRequest

 Clash Royale CLAN TAG#URR8PPP
Clash Royale CLAN TAG#URR8PPP
I have an apex class that submits opportunities for approval if they are over a certain threshold. This works great when processing small batches, but when trying to submit larger batches it fails with "Too many DML Statements".
I haven't been able to find anything that says I can process a list of records with the Approval.ProcessSubmitRequest class - so am doing it within a for loop. I tried swapping to a @future class for the Approval, but that has a limit of 50 @future calls as well.
Looking to bulkify this or identify an alternative option.
for(Opportunity o :lstOppty)
 String recordtypename = Schema.SObjectType.Opportunity.getRecordTypeInfosById().get(o.recordtypeid).getname();
 if(o.BSO_Audit_Flag__c && o.Last_Review_Date__c == null && opptyRTaudit.contains(recordtypename) && Approval.isLocked(o.id) == false)
 Approval.ProcessSubmitRequest req = new Approval.ProcessSubmitRequest();
 req.setComments('Opportunity was submitted for approval.');
 req.setObjectId(o.Id);
 try
 Approval.ProcessResult result = Approval.process(req);
 System.debug('Submitted for approval successfully: '+result.isSuccess());
 
 catch(Exception e) 
 System.debug('Submitted for approval failed. This usually means the BSO Alignment or Country on User profile is not set correctly. Error Message: = ' + e.getMessage());
 
 
apex approval-process bulkification approval
add a comment |
I have an apex class that submits opportunities for approval if they are over a certain threshold. This works great when processing small batches, but when trying to submit larger batches it fails with "Too many DML Statements".
I haven't been able to find anything that says I can process a list of records with the Approval.ProcessSubmitRequest class - so am doing it within a for loop. I tried swapping to a @future class for the Approval, but that has a limit of 50 @future calls as well.
Looking to bulkify this or identify an alternative option.
for(Opportunity o :lstOppty)
 String recordtypename = Schema.SObjectType.Opportunity.getRecordTypeInfosById().get(o.recordtypeid).getname();
 if(o.BSO_Audit_Flag__c && o.Last_Review_Date__c == null && opptyRTaudit.contains(recordtypename) && Approval.isLocked(o.id) == false)
 Approval.ProcessSubmitRequest req = new Approval.ProcessSubmitRequest();
 req.setComments('Opportunity was submitted for approval.');
 req.setObjectId(o.Id);
 try
 Approval.ProcessResult result = Approval.process(req);
 System.debug('Submitted for approval successfully: '+result.isSuccess());
 
 catch(Exception e) 
 System.debug('Submitted for approval failed. This usually means the BSO Alignment or Country on User profile is not set correctly. Error Message: = ' + e.getMessage());
 
 
apex approval-process bulkification approval
add a comment |
I have an apex class that submits opportunities for approval if they are over a certain threshold. This works great when processing small batches, but when trying to submit larger batches it fails with "Too many DML Statements".
I haven't been able to find anything that says I can process a list of records with the Approval.ProcessSubmitRequest class - so am doing it within a for loop. I tried swapping to a @future class for the Approval, but that has a limit of 50 @future calls as well.
Looking to bulkify this or identify an alternative option.
for(Opportunity o :lstOppty)
 String recordtypename = Schema.SObjectType.Opportunity.getRecordTypeInfosById().get(o.recordtypeid).getname();
 if(o.BSO_Audit_Flag__c && o.Last_Review_Date__c == null && opptyRTaudit.contains(recordtypename) && Approval.isLocked(o.id) == false)
 Approval.ProcessSubmitRequest req = new Approval.ProcessSubmitRequest();
 req.setComments('Opportunity was submitted for approval.');
 req.setObjectId(o.Id);
 try
 Approval.ProcessResult result = Approval.process(req);
 System.debug('Submitted for approval successfully: '+result.isSuccess());
 
 catch(Exception e) 
 System.debug('Submitted for approval failed. This usually means the BSO Alignment or Country on User profile is not set correctly. Error Message: = ' + e.getMessage());
 
 
apex approval-process bulkification approval
I have an apex class that submits opportunities for approval if they are over a certain threshold. This works great when processing small batches, but when trying to submit larger batches it fails with "Too many DML Statements".
I haven't been able to find anything that says I can process a list of records with the Approval.ProcessSubmitRequest class - so am doing it within a for loop. I tried swapping to a @future class for the Approval, but that has a limit of 50 @future calls as well.
Looking to bulkify this or identify an alternative option.
for(Opportunity o :lstOppty)
 String recordtypename = Schema.SObjectType.Opportunity.getRecordTypeInfosById().get(o.recordtypeid).getname();
 if(o.BSO_Audit_Flag__c && o.Last_Review_Date__c == null && opptyRTaudit.contains(recordtypename) && Approval.isLocked(o.id) == false)
 Approval.ProcessSubmitRequest req = new Approval.ProcessSubmitRequest();
 req.setComments('Opportunity was submitted for approval.');
 req.setObjectId(o.Id);
 try
 Approval.ProcessResult result = Approval.process(req);
 System.debug('Submitted for approval successfully: '+result.isSuccess());
 
 catch(Exception e) 
 System.debug('Submitted for approval failed. This usually means the BSO Alignment or Country on User profile is not set correctly. Error Message: = ' + e.getMessage());
 
 
apex approval-process bulkification approval
apex approval-process bulkification approval
asked Jan 21 at 20:18
jjurischjjurisch
538
538
add a comment |
add a comment |
 1 Answer
 1
 
active
oldest
votes
Note that the Approval.process method has a signature which accepts a List<Approval.ProcessRequest>:
public static Approval.ProcessResult process(Approval.ProcessRequest approvalRequests)
add a comment |
Your Answer
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "459"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsalesforce.stackexchange.com%2fquestions%2f247440%2fbulkify-apex-approval-processsubmitrequest%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
 1 Answer
 1
 
active
oldest
votes
 1 Answer
 1
 
active
oldest
votes
active
oldest
votes
active
oldest
votes
Note that the Approval.process method has a signature which accepts a List<Approval.ProcessRequest>:
public static Approval.ProcessResult process(Approval.ProcessRequest approvalRequests)
add a comment |
Note that the Approval.process method has a signature which accepts a List<Approval.ProcessRequest>:
public static Approval.ProcessResult process(Approval.ProcessRequest approvalRequests)
add a comment |
Note that the Approval.process method has a signature which accepts a List<Approval.ProcessRequest>:
public static Approval.ProcessResult process(Approval.ProcessRequest approvalRequests)
Note that the Approval.process method has a signature which accepts a List<Approval.ProcessRequest>:
public static Approval.ProcessResult process(Approval.ProcessRequest approvalRequests)
answered Jan 21 at 20:23


Adrian Larson♦Adrian Larson
108k19115243
108k19115243
add a comment |
add a comment |
Thanks for contributing an answer to Salesforce Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsalesforce.stackexchange.com%2fquestions%2f247440%2fbulkify-apex-approval-processsubmitrequest%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown