Loading

You have uncommitted work pending. Please commit or rollback before calling out. (Lavoro non confermato in sospeso. Confermare o abortire il lavoro prima di effettuare una chiamata).

Data pubblicazione: Mar 30, 2020
Descrizione

Può essere necessario creare un record e quindi aggiornarlo con informazioni fornite da un servizio Web. Tuttavia, non è possibile effettuare una chiamata a un servizio Web dopo un'istruzione DML all'interno della stessa transazione. Per ottenere l'azione richiesta, la transazione deve essere divisa in due parti, in modo che la transazione DML venga completata prima che venga effettuata la chiamata al servizio Web.

Risoluzione

Suddivisione di una transazione in due processi Ajax separati

Il primo inserisce il record e il secondo effettua la chiamata ed è in grado di aggiornare il record appena inserito.

Pagina TestWsCallout
<apex:page controller="TestWsCallout" tabstyle="Account">     <apex:form >         <apex:actionFunction action="{!InsertRecord}" name="InsertRecord_JS" Rerender="statuses" status="Status1" oncomplete="CallWebService_JS();"/>         <apex:actionFunction action="{!CallWebService}" name="CallWebService_JS" status="Status2" reRender="statuses, msg"/>         <apex:outputPanel id="statuses">             <apex:actionStatus id="Status1" startText="...Inserting Record Into DB..." />             <apex:actionStatus id="Status2" startText="...Calling Web Service..." />         </apex:outputPanel>         <apex:outputPanel id="msg">             <apex:pageMessages />         </apex:outputPanel>         <div><input name="DoAction" class="btn" type="button" value="Do Action" onclick="InsertRecord_JS();return false;"/></div>     </apex:form> </apex:page>

Classe TestWsCallout
public class TestWsCallout{          Account myAccount;         public PageReference InsertRecord() {         myAccount = new Account(name = 'Test Account');         insert myAccount;         // Calling a Web Service here would throw an exception         return null;     }          public PageReference CallWebService() {                  // Execute a call to a Web Service         HttpRequest req = new HttpRequest();         req.setEndpoint('http://MyWebService12345678790.com?id=' + myAccount.Id);         req.setMethod('GET');         HttpResponse response = new Http().send(req);                  // Simulate an update         myAccount.Name = 'Test Account 2';         update myAccount;                 ApexPages.addMessage(new ApexPages.Message(ApexPages.Severity.CONFIRM, 'WebService Called on New Account: ' + myAccount.Name));         return null;     } }
Numero articolo Knowledge

000385374

 
Caricamento
Salesforce Help | Article