एपेक्स - बैच प्रोसेसिंग

इस अध्याय में, हम एपेक्स में बैच प्रोसेसिंग को समझेंगे। एक परिदृश्य पर विचार करें, जिसमें हम बड़ी संख्या में दैनिक आधार पर प्रक्रिया करेंगे, शायद डेटा की सफाई या कुछ अप्रयुक्त डेटा को हटा सकते हैं।

बैच एपेक्स क्या है?

बैच एपेक्स कोड के अतुल्यकालिक निष्पादन है, विशेष रूप से बड़ी संख्या में रिकॉर्ड को संसाधित करने के लिए डिज़ाइन किया गया है और इसमें सिंक्रोनस कोड की तुलना में गवर्नर की सीमाओं में अधिक लचीलापन है।

बैच एपेक्स का उपयोग कब करें?

  • जब आप दैनिक आधार पर या अंतराल के विशिष्ट समय पर बड़ी संख्या में रिकॉर्ड करना चाहते हैं तो आप बैच एपेक्स के लिए जा सकते हैं।

  • इसके अलावा, जब आप एक ऑपरेशन को अतुल्यकालिक चाहते हैं तो आप बैच एपेक्स को लागू कर सकते हैं। बैच एपेक्स को एक इंटरफ़ेस के रूप में उजागर किया गया है जिसे डेवलपर द्वारा कार्यान्वित किया जाना चाहिए। एपेक्स का उपयोग करके बैच जॉब को रनटाइम पर प्रोग्राम किया जा सकता है। बैच एपेक्स रिकॉर्ड के छोटे बैचों पर काम करता है, जो आपके पूरे रिकॉर्ड सेट को कवर करता है और प्रसंस्करण को डेटा के प्रबंधनीय विखंडन तक तोड़ता है।

बैच एपेक्स का उपयोग करना

जब हम बैच एपेक्स का उपयोग कर रहे हैं, तो हमें Salesforce द्वारा प्रदान किए गए इंटरफ़ेस डेटाबेस को लागू करना चाहिए। उपलब्ध होने के बाद, और फिर प्रोग्राम को कक्षा में लागू करें।

आप इन चरणों का पालन करके कक्षा की निगरानी कर सकते हैं -

बैच एपेक्स बैच के निष्पादन को मॉनिटर या बंद करने के लिए, सेटअप → मॉनिटरिंग → एपेक्स जॉब्स या जॉब्स → एपेक्स जॉब्स पर जाएं।

डेटाबेस। उपलब्ध इंटरफ़ेस के निम्नलिखित तीन तरीके हैं जिन्हें लागू करने की आवश्यकता है -

  • Start
  • Execute
  • Finish

आइए अब प्रत्येक विधि को विस्तार से समझते हैं।

शुरू

प्रारंभ विधि डेटाबेस के तीन तरीकों में से एक है। उपलब्ध इंटरफ़ेस।

Syntax

global void execute(Database.BatchableContext BC, list<sobject<) {}

यह विधि बैच जॉब के प्रारंभ में बुलाई जाएगी और उस डेटा को एकत्रित करेगी जिस पर बैच जॉब संचालित होगी।

विधि को समझने के लिए निम्नलिखित बिंदुओं पर विचार करें -

  • उपयोग Database.QueryLocatorऑब्जेक्ट जब आप एक साधारण क्वेरी का उपयोग कर रहे हैं बैच की नौकरी में उपयोग की जाने वाली वस्तुओं के दायरे को उत्पन्न करने के लिए। इस स्थिति में, SOQL डेटा पंक्ति सीमा को बायपास किया जाएगा।

  • जब आप रिकॉर्ड को संसाधित करने के लिए जटिल मानदंड रखते हैं, तो उपयोग करने योग्य ऑब्जेक्ट का उपयोग करें। Database.QueryLocator उन अभिलेखों के दायरे को निर्धारित करता है जिन्हें संसाधित किया जाना चाहिए।

निष्पादित

आइए अब डेटाबेस.बेटेबल इंटरफ़ेस की एक्ज़ेक्यूट विधि को समझते हैं।

Syntax

global void execute(Database.BatchableContext BC, list<sobject<) {}

जहाँ, सूची <sObject <को डेटाबेस से जोड़ा जाता है।

इस पद्धति को स्टार्ट विधि के बाद कहा जाता है और बैच जॉब के लिए आवश्यक सभी प्रसंस्करण करता है।

समाप्त

अब हम डेटाबेस की फिनिश विधि पर चर्चा करेंगे।

Syntax

global void finish(Database.BatchableContext BC) {}

इस पद्धति को अंत में बुलाया जाता है और आप कुछ परिष्करण गतिविधियां कर सकते हैं जैसे कि बैच जॉब रिकॉर्ड्स के बारे में जानकारी के साथ ईमेल भेजना संसाधित और स्थिति।

बैच एपेक्स उदाहरण

आइए हम अपनी मौजूदा केमिकल कंपनी के एक उदाहरण पर विचार करें और यह मान लें कि हमें ग्राहक रिकॉर्ड के ग्राहक की स्थिति और ग्राहक विवरण फ़ील्ड को अपडेट करने की आवश्यकता है जिसे सक्रिय के रूप में चिह्नित किया गया है और जिसने आज की तारीख बनाई है। यह दैनिक आधार पर किया जाना चाहिए और बैच प्रसंस्करण की स्थिति के बारे में एक उपयोगकर्ता को एक ईमेल भेजा जाना चाहिए। ग्राहक स्थिति को 'संसाधित' और ग्राहक विवरण को 'अपडेटेड वाया बैच जॉब' के रूप में अपडेट करें।

// Batch Job for Processing the Records
global class CustomerProessingBatch implements Database.Batchable<sobject> {
   global String [] email = new String[] {'[email protected]'};
   // Add here your email address here
  
   // Start Method
   global Database.Querylocator start (Database.BatchableContext BC) {
      return Database.getQueryLocator('Select id, Name, APEX_Customer_Status__c,
      APEX_Customer_Decscription__c From APEX_Customer__c WHERE createdDate = today
      AND APEX_Active__c = true');
      // Query which will be determine the scope of Records fetching the same
   }
   
   // Execute method
   global void execute (Database.BatchableContext BC, List<sobject> scope) {
      List<apex_customer__c> customerList = new List<apex_customer__c>();
      List<apex_customer__c> updtaedCustomerList = new List<apex_customer__c>();
      
      // List to hold updated customer
      for (sObject objScope: scope) {
         APEX_Customer__c newObjScope = (APEX_Customer__c)objScope ;
         
         // type casting from generic sOject to APEX_Customer__c
         newObjScope.APEX_Customer_Decscription__c = 'Updated Via Batch Job';
         newObjScope.APEX_Customer_Status__c = 'Processed';
         updtaedCustomerList.add(newObjScope); // Add records to the List
         System.debug('Value of UpdatedCustomerList '+updtaedCustomerList);
      }
      
      if (updtaedCustomerList != null && updtaedCustomerList.size()>0) {
         // Check if List is empty or not
         Database.update(updtaedCustomerList); System.debug('List Size '
          + updtaedCustomerList.size());
         // Update the Records
      }
   }
   
   // Finish Method
   global void finish(Database.BatchableContext BC) {
      Messaging.SingleEmailMessage mail = new Messaging.SingleEmailMessage();
      
      // Below code will fetch the job Id
      AsyncApexJob a = [Select a.TotalJobItems, a.Status, a.NumberOfErrors,
      a.JobType, a.JobItemsProcessed, a.ExtendedStatus, a.CreatedById,
      a.CompletedDate From AsyncApexJob a WHERE id = :BC.getJobId()];
      
      // get the job Id
      System.debug('$$$ Jobid is'+BC.getJobId());
      
      // below code will send an email to User about the status
      mail.setToAddresses(email);
      mail.setReplyTo('[email protected]'); // Add here your email address
      mail.setSenderDisplayName('Apex Batch Processing Module');
      mail.setSubject('Batch Processing '+a.Status);
      mail.setPlainTextBody('The Batch Apex job processed'
         + a.TotalJobItems+'batches with '+a.NumberOfErrors+'failures'+'Job Item
      processed are'+a.JobItemsProcessed);
      Messaging.sendEmail(new Messaging.Singleemailmessage [] {mail});
   }
}

इस कोड को निष्पादित करने के लिए, पहले इसे सहेजें और फिर निम्नलिखित कोड को निष्पादित अनाम में पेस्ट करें। यह क्लास का ऑब्जेक्ट बनाएगा और डेटाबेस.टेक्स्ट विधि बैच जॉब को निष्पादित करेगा। एक बार जब नौकरी पूरी हो जाती है, तो एक ईमेल निर्दिष्ट ईमेल पते पर भेजा जाएगा। सुनिश्चित करें कि आपके पास एक ग्राहक रिकॉर्ड है जो कि हैActive के रूप में जाँच की।

// Paste in Developer Console
CustomerProessingBatch objClass = new CustomerProessingBatch();
Database.executeBatch (objClass);

एक बार जब यह वर्ग निष्पादित हो जाता है, तो आपके द्वारा प्रदान किए गए ईमेल पते की जांच करें जहां आपको जानकारी के साथ ईमेल प्राप्त होगा। इसके अलावा, आप मॉनिटरिंग पेज और ऊपर दिए गए चरणों के माध्यम से बैच की नौकरी की स्थिति की जांच कर सकते हैं।

यदि आप डिबग लॉग की जांच करते हैं, तो आप सूची आकार पा सकते हैं जो इंगित करता है कि कितने रिकॉर्ड संसाधित किए गए हैं।

Limitations

हम एक समय में केवल 5 बैच की नौकरी कर सकते हैं। यह बैच एपेक्स की सीमाओं में से एक है।

एपेक्स विवरण पृष्ठ का उपयोग करके एपेक्स बैच जॉब का निर्धारण

आप एपेक्स क्लास को एपेक्स डिटेल पेज के जरिए शेड्यूल कर सकते हैं -

Step 1 - सेटअप ⇒ एपेक्स क्लासेस पर जाएं, एपेक्स क्लासेस पर क्लिक करें।

Step 2 - शेड्यूल एपेक्स बटन पर क्लिक करें।

Step 3 - जानकारी प्रदान करें।

शेड्यूल किए गए इंटरफ़ेस का उपयोग करके एपेक्स बैच जॉब को शेड्यूल करना

आप शेड्यूल किए गए इंटरफ़ेस का उपयोग करके एपेक्स बैच जॉब को शेड्यूल कर सकते हैं -

// Batch Job for Processing the Records
global class CustomerProessingBatch implements Database.Batchable<sobject> {
   global String [] email = new String[] {'[email protected]'};
   // Add here your email address here
   
   // Start Method
   global Database.Querylocator start (Database.BatchableContext BC) {
      return Database.getQueryLocator('Select id, Name, APEX_Customer_Status__c,
      APEX_Customer_Decscription__c From APEX_Customer__c WHERE createdDate = today
      AND APEX_Active__c = true');
      // Query which will be determine the scope of Records fetching the same
   }
   
   // Execute method
   global void execute (Database.BatchableContext BC, List<sobject> scope) {
      List<apex_customer__c> customerList = new List<apex_customer__c>();
      List<apex_customer__c> updtaedCustomerList = new
      List<apex_customer__c>();//List to hold updated customer
      
      for (sObject objScope: scope) {
         APEX_Customer__c newObjScope = (APEX_Customer__c)objScope ;//type
         casting from generic sOject to APEX_Customer__c
         newObjScope.APEX_Customer_Decscription__c = 'Updated Via Batch Job';
         newObjScope.APEX_Customer_Status__c = 'Processed';
         updtaedCustomerList.add(newObjScope);//Add records to the List
         System.debug('Value of UpdatedCustomerList '+updtaedCustomerList);
      }
      
      if (updtaedCustomerList != null && updtaedCustomerList.size()>0) {
         // Check if List is empty or not
         Database.update(updtaedCustomerList); System.debug('List Size'
            + updtaedCustomerList.size());
         // Update the Records
      }
   }
 
   // Finish Method
   global void finish(Database.BatchableContext BC) {
      Messaging.SingleEmailMessage mail = new Messaging.SingleEmailMessage();
      
      // Below code will fetch the job Id
      AsyncApexJob a = [Select a.TotalJobItems, a.Status, a.NumberOfErrors,
      a.JobType, a.JobItemsProcessed, a.ExtendedStatus, a.CreatedById,
      a.CompletedDate From AsyncApexJob a WHERE id = :BC.getJobId()];//get the job Id
      System.debug('$$$ Jobid is'+BC.getJobId());
      
      // below code will send an email to User about the status
      mail.setToAddresses(email);
      mail.setReplyTo('[email protected]');//Add here your email address
      mail.setSenderDisplayName('Apex Batch Processing Module');
      mail.setSubject('Batch Processing '+a.Status);
      mail.setPlainTextBody('The Batch Apex job processed' 
         + a.TotalJobItems+'batches with '+a.NumberOfErrors+'failures'+'Job Item
      processed are'+a.JobItemsProcessed);
      Messaging.sendEmail(new Messaging.Singleemailmessage [] {mail});
   }
   
   // Scheduler Method to scedule the class
   global void execute(SchedulableContext sc) {
      CustomerProessingBatch conInstance = new CustomerProessingBatch();
      database.executebatch(conInstance,100);
   }
}

// Paste in Developer Console
CustomerProessingBatch objClass = new CustomerProcessingBatch();
Database.executeBatch (objClass);