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