Apex-데이터베이스 방법

데이터베이스 클래스 메서드는 삽입, 업데이트 등과 같은 DML 문보다 더 유연한 DML 문으로 작업하는 또 다른 방법입니다.

데이터베이스 메서드와 DML 문의 차이점

DML 문 데이터베이스 방법
부분 업데이트는 허용되지 않습니다. 예를 들어, 목록에 20 개의 레코드가있는 경우 모든 레코드가 업데이트되거나 전혀 업데이트되지 않습니다. 부분 업데이트가 허용됩니다. Parameter in Database 메서드를 true 또는 false로 지정하고 부분 업데이트를 허용하려면 true를 지정하고 동일하지 않으면 false를 지정할 수 있습니다.
성공 및 실패 레코드 목록을 가져올 수 없습니다. 예제에서 본 것처럼 성공 및 실패 레코드 목록을 얻을 수 있습니다.
Example − listName 삽입 Example − Database.insert (listName, False), 여기서 false는 부분 업데이트가 허용되지 않음을 나타냅니다.

작업 삽입

데이터베이스 방법을 통해 새 레코드를 삽입하는 것도 매우 간단하고 유연합니다. DML 문을 사용하여 새 레코드를 삽입 한 이전 시나리오를 고려해 보겠습니다. 데이터베이스 메소드를 사용하여 동일한 것을 삽입 할 것입니다.

// Insert Operation Using Database methods
// Insert Customer Records First using simple DML Statement. This Customer Record will be
// used when we will create Invoice Records
APEX_Customer__c objCust = new APEX_Customer__C();
objCust.Name = 'Test';
insert objCust; // Inserting the Customer Records

// Insert Operation Using Database methods
APEX_Invoice__c objNewInvoice = new APEX_Invoice__c();
List<apex_invoice__c> InvoiceListToInsert = new List<apex_invoice__c>();
objNewInvoice.APEX_Status__c = 'Pending';
objNewInvoice.APEX_Customer__c = objCust.id;
objNewInvoice.APEX_Amount_Paid__c = 1000;
InvoiceListToInsert.add(objNewInvoice);
Database.SaveResult[] srList = Database.insert(InvoiceListToInsert, false);

// Database method to insert the records in List
// Iterate through each returned result by the method

for (Database.SaveResult sr : srList) {
   if (sr.isSuccess()) {
      // This condition will be executed for successful records and will fetch the ids 
      // of successful records
      System.debug('Successfully inserted Invoice. Invoice ID: ' + sr.getId());
      // Get the invoice id of inserted Account
   } else {
      // This condition will be executed for failed records
      for(Database.Error objErr : sr.getErrors()) {
         System.debug('The following error has occurred.');
         
         // Printing error message in Debug log
         System.debug(objErr.getStatusCode() + ': ' + objErr.getMessage());
         System.debug('Invoice oject field which are affected by the error:' 
            + objErr.getFields());
      }
   }
}

업데이트 작업

이제 데이터베이스 방법을 사용한 비즈니스 사례를 고려해 보겠습니다. Invoice 객체의 상태 필드를 업데이트해야하지만 동시에 레코드 상태, 실패한 레코드 ID, 성공 횟수 등과 같은 정보도 필요하다고 가정합니다. DML 문을 사용하면 불가능하므로 Database 메서드를 사용해야합니다. 작업 상태를 확인합니다.

인보이스가 '보류 중'상태이고 생성 날짜가 오늘 인 경우 인보이스의 '상태'필드를 업데이트합니다.

아래에 제공된 코드는 Database.update 메서드를 사용하여 송장 레코드를 업데이트하는 데 도움이됩니다. 또한이 코드를 실행하기 전에 송장 레코드를 만드십시오.

// Code to update the records using the Database methods
List<apex_invoice__c> invoiceList = [SELECT id, Name, APEX_Status__c,
   createdDate FROM APEX_Invoice__c WHERE createdDate = today];

// fetch the invoice created today
List<apex_invoice__c> updatedInvoiceList = new List<apex_invoice__c>();
for (APEX_Invoice__c objInvoice: invoiceList) {
   if (objInvoice.APEX_Status__c == 'Pending') {
      objInvoice.APEX_Status__c = 'Paid';
      updatedInvoiceList.add(objInvoice);    //Adding records to the list
   }
}

Database.SaveResult[] srList = Database.update(updatedInvoiceList, false);
// Database method to update the records in List

// Iterate through each returned result by the method
for (Database.SaveResult sr : srList) {
   if (sr.isSuccess()) {
      // This condition will be executed for successful records and will fetch
      // the ids of successful records
      System.debug('Successfully updated Invoice. Invoice ID is : ' + sr.getId());
   } else {
      // This condition will be executed for failed records
      for(Database.Error objErr : sr.getErrors()) {
         System.debug('The following error has occurred.');
         
         // Printing error message in Debug log
         System.debug(objErr.getStatusCode() + ': ' + objErr.getMessage());
         System.debug('Invoice oject field which are affected by the error:' 
            + objErr.getFields());
      }
   }
}

이 자습서에서는 삽입 및 업데이트 작업 만 살펴볼 것입니다. 다른 작업은 이러한 작업 및 지난 장에서 수행 한 작업과 매우 유사합니다.