एपेक्स - डीएमएल
इस अध्याय में, हम चर्चा करेंगे कि सेल्सफोर्स में अलग-अलग डाटाबेस संशोधन कार्य कैसे करें। वहाँ दो कहते हैं जिसके साथ हम कार्य कर सकते हैं।
DML कथन
डीएमएल वे क्रियाएं हैं जो इन्सर्ट, अपडेट, डिलीट, अपटेरर, रिकॉर्ड्स को रिस्टोर करने, रिकॉर्ड्स को मर्ज करने या लीड ऑपरेशन को परिवर्तित करने के लिए की जाती हैं।
डीएमएल एपेक्स में सबसे महत्वपूर्ण हिस्सा है क्योंकि लगभग हर व्यापारिक मामले में डेटाबेस में परिवर्तन और संशोधन शामिल हैं।
डेटाबेस के तरीके
सभी ऑपरेशन जो आप डीएमएल स्टेटमेंट का उपयोग करके कर सकते हैं, उन्हें डेटाबेस के तरीकों का उपयोग करके भी किया जा सकता है। डेटाबेस विधियाँ सिस्टम विधियाँ हैं जिनका उपयोग आप DML संचालन करने के लिए कर सकते हैं। डेटाबेस विधियाँ डीएमएल स्टेटमेंट की तुलना में अधिक लचीलापन प्रदान करती हैं।
इस अध्याय में, हम DML कथन का उपयोग करते हुए पहले दृष्टिकोण को देखेंगे। हम एक बाद के अध्याय में डेटाबेस के तरीकों को देखेंगे।
DML कथन
आइए अब हम फिर से रासायनिक आपूर्तिकर्ता कंपनी के उदाहरण पर विचार करें। हमारे इनवॉइस रिकॉर्ड्स में स्टेटस, अमाउंट पेड, अमाउंट रिमेनिंग, नेक्स्ट पे डेट और इनवॉइस नंबर के रूप में फ़ील्ड हैं। आज जो चालान बनाए गए हैं और उनकी स्थिति 'लंबित' के रूप में है, उन्हें 'भुगतान' के लिए अद्यतन किया जाना चाहिए।
ऑपरेशन डालें
डेटाबेस में नए रिकॉर्ड बनाने के लिए इन्सर्ट ऑपरेशन का उपयोग किया जाता है। आप इन्सर्ट डीएमएल स्टेटमेंट का उपयोग करके किसी भी मानक या कस्टम ऑब्जेक्ट के रिकॉर्ड बना सकते हैं।
Example
हम APEX_Invoice__c ऑब्जेक्ट में नए रिकॉर्ड बना सकते हैं क्योंकि हर दिन नए ग्राहक के आदेश के लिए नए चालान बनाए जा रहे हैं। हम पहले एक ग्राहक रिकॉर्ड बनाएंगे और फिर हम उस नए ग्राहक रिकॉर्ड के लिए चालान रिकॉर्ड बना सकते हैं।
// fetch the invoices created today, Note, you must have at least one invoice
// created today
List<apex_invoice__c> invoiceList = [SELECT id, Name, APEX_Status__c,
createdDate FROM APEX_Invoice__c WHERE createdDate = today];
// create List to hold the updated invoice records
List<apex_invoice__c> updatedInvoiceList = new List<apex_invoice__c>();
APEX_Customer__c objCust = new APEX_Customer__C();
objCust.Name = 'Test ABC';
//DML for Inserting the new Customer Records
insert objCust;
for (APEX_Invoice__c objInvoice: invoiceList) {
if (objInvoice.APEX_Status__c == 'Pending') {
objInvoice.APEX_Status__c = 'Paid';
updatedInvoiceList.add(objInvoice);
}
}
// DML Statement to update the invoice status
update updatedInvoiceList;
// Prints the value of updated invoices
System.debug('List has been updated and updated values are' + updatedInvoiceList);
// Inserting the New Records using insert DML statement
APEX_Invoice__c objNewInvoice = new APEX_Invoice__c();
objNewInvoice.APEX_Status__c = 'Pending';
objNewInvoice.APEX_Amount_Paid__c = 1000;
objNewInvoice.APEX_Customer__c = objCust.id;
// DML which is creating the new Invoice record which will be linked with newly
// created Customer record
insert objNewInvoice;
System.debug('New Invoice Id is '+objNewInvoice.id+' and the Invoice Number is'
+ objNewInvoice.Name);
अद्यतन अद्यतन
अपडेट ऑपरेशन मौजूदा रिकॉर्ड पर अपडेट करने के लिए है। इस उदाहरण में, हम एक मौजूदा इनवॉइस रिकॉर्ड की स्थिति फ़ील्ड को 'भुगतान' के लिए अपडेट कर रहे हैं।
Example
// Update Statement Example for updating the invoice status. You have to create
and Invoice records before executing this code. This program is updating the
record which is at index 0th position of the List.
// First, fetch the invoice created today
List<apex_invoice__c> invoiceList = [SELECT id, Name, APEX_Status__c,
createdDate FROM APEX_Invoice__c];
List<apex_invoice__c> updatedInvoiceList = new List<apex_invoice__c>();
// Update the first record in the List
invoiceList[0].APEX_Status__c = 'Pending';
updatedInvoiceList.add(invoiceList[0]);
// DML Statement to update the invoice status
update updatedInvoiceList;
// Prints the value of updated invoices
System.debug('List has been updated and updated values of records are'
+ updatedInvoiceList[0]);
ऊपर का संचालन
अपग्रेड ऑपरेशन का उपयोग अपडेट ऑपरेशन करने के लिए किया जाता है और यदि अपडेट किए जाने वाले रिकॉर्ड डेटाबेस में मौजूद नहीं हैं, तो नए रिकॉर्ड भी बनाएं।
Example
मान लीजिए, ग्राहक ऑब्जेक्ट में ग्राहक रिकॉर्ड को अपडेट करने की आवश्यकता है। हम मौजूदा ग्राहक रिकॉर्ड को अपडेट करेंगे यदि यह पहले से मौजूद है, तो एक नया बनाएं। यह APEX_External_Id__c फ़ील्ड के मान पर आधारित होगा। यह क्षेत्र यह पहचानने के लिए हमारा क्षेत्र होगा कि रिकॉर्ड पहले से मौजूद हैं या नहीं।
Note - इस कोड को निष्पादित करने से पहले, ग्राहक आईडी में बाहरी आईडी फ़ील्ड मान '12341' के साथ रिकॉर्ड बनाएं और फिर नीचे दिए गए कोड को निष्पादित करें -
// Example for upserting the Customer records
List<apex_customer__c> CustomerList = new List<apex_customer__c>();
for (Integer i = 0; i < 10; i++) {
apex_customer__c objcust=new apex_customer__c(name = 'Test' +i,
apex_external_id__c='1234' +i);
customerlist.add(objcust);
} //Upserting the Customer Records
upsert CustomerList;
System.debug('Code iterated for 10 times and created 9 records as one record with
External Id 12341 is already present');
for (APEX_Customer_c objCustomer: CustomerList) {
if (objCustomer.APEX_External_Id_c == '12341') {
system.debug('The Record which is already present is '+objCustomer);
}
}
ऑपरेशन हटाएँ
आप डिलीट डीएमएल का उपयोग करके डिलीट ऑपरेशन कर सकते हैं।
Example
इस मामले में, हम उन चालानों को हटा देंगे जो परीक्षण के उद्देश्य के लिए बनाए गए हैं, यही वे नाम हैं जिनमें 'परीक्षण' नाम है।
आप इस स्निपेट को डेवलपर कंसोल से और साथ ही क्लास बनाए बिना निष्पादित कर सकते हैं।
// fetch the invoice created today
List<apex_invoice__c> invoiceList = [SELECT id, Name, APEX_Status__c,
createdDate FROM APEX_Invoice__c WHERE createdDate = today];
List<apex_invoice__c> updatedInvoiceList = new List<apex_invoice__c>();
APEX_Customer__c objCust = new APEX_Customer__C();
objCust.Name = 'Test';
// Inserting the Customer Records
insert objCust;
for (APEX_Invoice__c objInvoice: invoiceList) {
if (objInvoice.APEX_Status__c == 'Pending') {
objInvoice.APEX_Status__c = 'Paid';
updatedInvoiceList.add(objInvoice);
}
}
// DML Statement to update the invoice status
update updatedInvoiceList;
// Prints the value of updated invoices
System.debug('List has been updated and updated values are' + updatedInvoiceList);
// Inserting the New Records using insert DML statement
APEX_Invoice__c objNewInvoice = new APEX_Invoice__c();
objNewInvoice.APEX_Status__c = 'Pending';
objNewInvoice.APEX_Amount_Paid__c = 1000;
objNewInvoice.APEX_Customer__c = objCust.id;
// DML which is creating the new record
insert objNewInvoice;
System.debug('New Invoice Id is' + objNewInvoice.id);
// Deleting the Test invoices from Database
// fetch the invoices which are created for Testing, Select name which Customer Name
// is Test.
List<apex_invoice__c> invoiceListToDelete = [SELECT id FROM APEX_Invoice__c
WHERE APEX_Customer__r.Name = 'Test'];
// DML Statement to delete the Invoices
delete invoiceListToDelete;
System.debug('Success, '+invoiceListToDelete.size()+' Records has been deleted');
संचालन हटाना रद्द करें
आप हटाए गए रिकॉर्ड को हटा सकते हैं और रीसायकल बिन में मौजूद है। सभी रिश्ते जो हटाए गए रिकॉर्ड हैं, उन्हें भी पुनर्स्थापित किया जाएगा।
Example
मान लीजिए, पिछले उदाहरण में हटाए गए रिकॉर्ड्स को पुनर्स्थापित करने की आवश्यकता है। यह निम्नलिखित उदाहरण का उपयोग करके प्राप्त किया जा सकता है। पिछले उदाहरण में कोड को इस उदाहरण के लिए संशोधित किया गया है।
// fetch the invoice created today
List<apex_invoice__c> invoiceList = [SELECT id, Name, APEX_Status__c,
createdDate FROM APEX_Invoice__c WHERE createdDate = today];
List<apex_invoice__c> updatedInvoiceList = new List<apex_invoice__c>();
APEX_Customer__c objCust = new APEX_Customer__C();
objCust.Name = 'Test';
// Inserting the Customer Records
insert objCust;
for (APEX_Invoice__c objInvoice: invoiceList) {
if (objInvoice.APEX_Status__c == 'Pending') {
objInvoice.APEX_Status__c = 'Paid';
updatedInvoiceList.add(objInvoice);
}
}
// DML Statement to update the invoice status
update updatedInvoiceList;
// Prints the value of updated invoices
System.debug('List has been updated and updated values are' + updatedInvoiceList);
// Inserting the New Records using insert DML statement
APEX_Invoice__c objNewInvoice = new APEX_Invoice__c();
objNewInvoice.APEX_Status__c = 'Pending';
objNewInvoice.APEX_Amount_Paid__c = 1000;
objNewInvoice.APEX_Customer__c = objCust.id;
// DML which is creating the new record
insert objNewInvoice;
System.debug('New Invoice Id is '+objNewInvoice.id);
// Deleting the Test invoices from Database
// fetch the invoices which are created for Testing, Select name which Customer Name
// is Test.
List<apex_invoice__c> invoiceListToDelete = [SELECT id FROM APEX_Invoice__c
WHERE APEX_Customer__r.Name = 'Test'];
// DML Statement to delete the Invoices
delete invoiceListToDelete;
system.debug('Deleted Record Count is ' + invoiceListToDelete.size());
System.debug('Success, '+invoiceListToDelete.size() + 'Records has been deleted');
// Restore the deleted records using undelete statement
undelete invoiceListToDelete;
System.debug('Undeleted Record count is '+invoiceListToDelete.size()+'. This should
be same as Deleted Record count');