एपेक्स - डाटाबेस मेथड्स
डेटाबेस क्लास विधियाँ डीएमएल स्टेटमेंट के साथ काम करने का एक और तरीका है जो डीएमएल स्टेटमेंट्स जैसे इन्सर्ट, अपडेट इत्यादि से अधिक लचीला है।
डेटाबेस मेथड्स और डीएमएल स्टेटमेंट्स के बीच अंतर
| DML कथन | डेटाबेस के तरीके | 
|---|---|
| आंशिक अद्यतन की अनुमति नहीं है। उदाहरण के लिए, यदि आपके पास सूची में 20 रिकॉर्ड हैं, तो या तो सभी रिकॉर्ड अपडेट किए जाएंगे या कोई भी नहीं। | आंशिक अद्यतन की अनुमति है। आप डेटाबेस विधि में पैरामीटर को सही या गलत के रूप में निर्दिष्ट कर सकते हैं, आंशिक अद्यतन की अनुमति देने के लिए सही है और उसी की अनुमति नहीं देने के लिए गलत है। | 
| आपको सफलता और असफल रिकॉर्ड की सूची नहीं मिल सकती है। | आप सफलता और असफल रिकॉर्ड की सूची प्राप्त कर सकते हैं जैसा कि हमने उदाहरण में देखा है। | 
| Example - सूची का नाम डालें | Example - डेटाबेस.इन्टर (सूचीनाम, गलत), जहां गलत संकेत देता है कि आंशिक अद्यतन की अनुमति नहीं है। | 
ऑपरेशन डालें
डेटाबेस विधियों के माध्यम से नए रिकॉर्ड सम्मिलित करना भी काफी सरल और लचीला है। पिछले परिदृश्य पर विचार करें, जिसमें हमने 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());
      }
   }
}अद्यतन अद्यतन
आइए अब डेटाबेस विधियों का उपयोग करके हमारे व्यवसाय के मामले के उदाहरण पर विचार करें। माना कि हमें इनवॉइस ऑब्जेक्ट के स्थिति क्षेत्र को अपडेट करने की आवश्यकता है, लेकिन साथ ही, हमें रिकॉर्ड्स की स्थिति, रिकॉर्ड किए गए रिकॉर्ड आईडी, सफलता गणना आदि जैसी जानकारी की भी आवश्यकता होती है, यह डीएमएल विवरणों का उपयोग करके संभव नहीं है, इसलिए हमें डेटाबेस विधियों का उपयोग करना चाहिए हमारे ऑपरेशन की स्थिति पाने के लिए।
उदाहरण
अगर यह स्थिति 'लंबित' है और निर्माण की तिथि आज है, तो हम चालान की 'स्थिति' फ़ील्ड को अपडेट करेंगे।
नीचे दिया गया कोड 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());
      }
   }
}हम इस ट्यूटोरियल में केवल इन्सर्ट और अपडेट ऑपरेशन्स को देख रहे हैं। अन्य ऑपरेशन इन ऑपरेशनों के काफी समान हैं और हमने पिछले अध्याय में क्या किया था।