Apex-일괄 처리

이 장에서는 Apex의 일괄 처리에 대해 설명합니다. 매일 많은 수의 레코드를 처리하는 시나리오를 생각해보십시오. 데이터를 정리하거나 사용하지 않는 데이터를 삭제할 수 있습니다.

Batch Apex 란 무엇입니까?

Batch Apex는 많은 수의 레코드를 처리하도록 특별히 설계된 Apex 코드의 비동기 실행이며 동기 코드보다 거버너 제한이 더 유연합니다.

Batch Apex는 언제 사용합니까?

  • 매일 또는 특정 시간 간격으로 많은 수의 레코드를 처리하려는 경우 Batch Apex를 사용할 수 있습니다.

  • 또한 작업을 비 동기화하려는 경우 Batch Apex를 구현할 수 있습니다. Batch Apex는 개발자가 구현해야하는 인터페이스로 노출됩니다. 배치 작업은 Apex를 사용하여 런타임에 프로그래밍 방식으로 호출 할 수 있습니다. Batch Apex는 소량의 레코드 배치에서 작동하여 전체 레코드 세트를 다루고 처리를 관리 가능한 데이터 청크로 세분화합니다.

Batch Apex 사용

Batch Apex를 사용하는 경우 Salesforce 제공 인터페이스 Database.Batchable을 구현 한 다음 프로그래밍 방식으로 클래스를 호출해야합니다.

다음 단계에 따라 수업을 모니터링 할 수 있습니다.

배치 Apex 배치 작업 실행을 모니터링하거나 중지하려면 설정 → 모니터링 → Apex 작업 또는 작업 → Apex 작업으로 이동합니다.

Database.Batchable 인터페이스에는 구현해야하는 다음 세 가지 방법이 있습니다.

  • Start
  • Execute
  • Finish

이제 각 방법을 자세히 이해하겠습니다.

스타트

Start 메서드는 Database.Batchable 인터페이스의 세 가지 메서드 중 하나입니다.

Syntax

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

이 메서드는 배치 작업을 시작할 때 호출되며 배치 작업이 작동 할 데이터를 수집합니다.

방법을 이해하려면 다음 사항을 고려하십시오.

  • 사용 Database.QueryLocator간단한 쿼리를 사용하여 일괄 작업에 사용되는 개체의 범위를 생성하는 경우 개체입니다. 이 경우 SOQL 데이터 행 제한이 무시됩니다.

  • 레코드를 처리하기위한 복잡한 기준이있는 경우 반복 가능한 객체를 사용합니다. Database.QueryLocator는 처리해야하는 레코드의 범위를 결정합니다.

실행

이제 Database.Batchable 인터페이스의 Execute 메서드를 이해하겠습니다.

Syntax

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

여기서 list <sObject <는 Database.QueryLocator 메서드에 의해 반환됩니다.

이 메서드는 Start 메서드 이후에 호출되며 Batch Job에 필요한 모든 처리를 수행합니다.

이제 Database.Batchable 인터페이스의 Finish 메서드에 대해 설명합니다.

Syntax

global void finish(Database.BatchableContext BC) {}

이 메서드는 마지막에 호출되며 처리 된 일괄 작업 레코드 및 상태에 대한 정보가 포함 된 이메일을 보내는 것과 같은 몇 가지 마무리 작업을 수행 할 수 있습니다.

배치 Apex 예

기존 화학 회사의 예를 고려하고 활성으로 표시되고 날짜가 오늘로 생성 된 고객 기록의 고객 상태 및 고객 설명 필드를 업데이트해야한다고 가정하겠습니다. 이 작업은 매일 수행해야하며 일괄 처리 상태에 대한 이메일을 사용자에게 보내야합니다. 고객 상태를 '처리됨'으로 업데이트하고 고객 설명을 '일괄 작업을 통해 업데이트 됨'으로 업데이트합니다.

// 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});
   }
}

이 코드를 실행하려면 먼저 저장 한 다음 익명 실행에 다음 코드를 붙여 넣습니다. 그러면 클래스의 객체가 생성되고 Database.execute 메서드는 Batch 작업을 실행합니다. 작업이 완료되면 지정된 이메일 주소로 이메일이 전송됩니다. 다음과 같은 고객 기록이 있는지 확인하십시오.Active 확인.

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

이 수업이 실행되면 정보가 포함 된 이메일을받을 이메일 주소를 확인하세요. 또한 위에 제공된 모니터링 페이지 및 단계를 통해 배치 작업의 상태를 확인할 수 있습니다.

디버그 로그를 확인하면 처리 된 레코드 수를 나타내는 목록 크기를 찾을 수 있습니다.

Limitations

한 번에 5 개의 일괄 작업 만 처리 할 수 ​​있습니다. 이것은 Batch Apex의 제한 사항 중 하나입니다.

Apex 세부 정보 페이지를 사용하여 Apex 일괄 작업 예약

아래와 같이 Apex 세부 정보 페이지를 통해 Apex 클래스를 예약 할 수 있습니다.

Step 1 − 설정 ⇒ Apex 클래스로 이동하여 Apex 클래스를 클릭합니다.

Step 2 − Apex 예약 버튼을 클릭합니다.

Step 3 − 세부 정보를 제공합니다.

예약 가능한 인터페이스를 사용하여 Apex 배치 작업 예약

다음과 같이 예약 가능한 인터페이스를 사용하여 Apex 배치 작업을 예약 할 수 있습니다.

// 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);