एपेक्स - SOQL

यह सेल्सफोर्स ऑब्जेक्ट क्वेरी लैंग्वेज है जिसे SFDC डेटाबेस के साथ काम करने के लिए डिज़ाइन किया गया है। यह किसी एकल मानदंड में दिए गए मानदंड पर एक रिकॉर्ड खोज सकता है।

SOSL की तरह, यह कई ऑब्जेक्ट्स पर खोज नहीं कर सकता है लेकिन यह नेस्टेड क्वेरीज़ का समर्थन करता है।

SOQL उदाहरण

केमिकल कंपनी के हमारे मौजूदा उदाहरण पर विचार करें। मान लीजिए, हमें उन रिकॉर्डों की एक सूची चाहिए, जो आज बनाए गए हैं और जिनके ग्राहक का नाम 'परीक्षण' नहीं है। इस स्थिति में, हमें नीचे दिए गए अनुसार SOQL क्वेरी का उपयोग करना होगा -

// fetching the Records via SOQL
List<apex_invoice__c> InvoiceList = new List<apex_invoice__c>();
InvoiceList = [SELECT Id, Name, APEX_Customer__r.Name, APEX_Status__c FROM
   APEX_Invoice__c WHERE createdDate = today AND APEX_Customer__r.Name != 'Test'];
// SOQL query for given criteria

// Printing the fetched records
System.debug('We have total '+InvoiceList.size()+' Records in List');

for (APEX_Invoice__c objInvoice: InvoiceList) {
   System.debug('Record Value is '+objInvoice); 
   // Printing the Record fetched
}

आप नीचे दिखाए गए अनुसार डेवलपर कंसोल में क्वेरी संपादक के माध्यम से SOQL क्वेरी चला सकते हैं।

नीचे दिए गए क्वेरी को डेवलपर कंसोल में चलाएं। आज बनाए गए इनवॉइस रिकॉर्ड्स को खोजें।

SELECT Id, Name, APEX_Customer__r.Name, APEX_Status__c FROM APEX_Invoice__c
   WHERE createdDate = today

आपको उन फ़ील्ड्स का चयन करना होगा जिनके लिए आपको मूल्यों की आवश्यकता है, अन्यथा, यह समय त्रुटियों को फेंक सकता है।

रिश्ते के क्षेत्र का पता लगाना

यह एसएफडीसी में सबसे महत्वपूर्ण भागों में से एक है क्योंकि कई बार हमें मूल बच्चे वस्तु संबंध के माध्यम से पार करने की आवश्यकता होती है

इसके अलावा, ऐसे मामले भी हो सकते हैं जब आपको डेटाबेस में दो संबद्ध ऑब्जेक्ट रिकॉर्ड सम्मिलित करने की आवश्यकता होती है। उदाहरण के लिए, इनवॉइस ऑब्जेक्ट का ग्राहक ऑब्जेक्ट के साथ संबंध है और इसलिए एक ग्राहक के पास कई चालान हो सकते हैं।

मान लीजिए, आप चालान बना रहे हैं और फिर आपको इस चालान को ग्राहक से संबंधित करना होगा। आप इस कार्यक्षमता के लिए निम्न कोड का उपयोग कर सकते हैं -

// Now create the invoice record and relate it with the Customer object
// Before executing this, please create a Customer Records with Name 'Customer
// Creation Test'
APEX_Invoice__c objInvoice = new APEX_Invoice__c();

// Relating Invoice to customer via id field of Customer object
objInvoice.APEX_Customer__c = [SELECT id FROM APEX_Customer__c WHERE Name =
   'Customer Creation Test' LIMIT 1].id;
objInvoice.APEX_Status__c = 'Pending';
insert objInvoice;  //Creating Invoice
System.debug('Newly Created Invoice'+objInvoice);  //Newly created invoice

डेवलपर कंसोल में इस कोड स्निपेट को निष्पादित करें। एक बार निष्पादित होने के बाद, डेवलपर कंसोल से चालान की आईडी कॉपी करें और फिर एसएफडीसी में समान खोलें जैसा कि नीचे दिखाया गया है। आप देख सकते हैं कि नीचे दिखाए गए अनुसार पेरेंट रिकॉर्ड को पहले ही इनवॉइस रिकॉर्ड को सौंपा जा चुका है।

बाल रिकॉर्ड प्राप्त करना

आइए अब एक उदाहरण पर विचार करें जिसमें, विशेष ग्राहक रिकॉर्ड से संबंधित सभी चालानों को एक स्थान पर होना चाहिए। इसके लिए आपको बच्चे के रिश्ते का नाम पता होना चाहिए। बाल संबंध नाम देखने के लिए, चाइल्ड ऑब्जेक्ट पर फ़ील्ड डिटेल पेज पर जाएं और "चाइल्ड रिलेशनशिप" मान जांचें। हमारे उदाहरण में, यह अंत में __r द्वारा संलग्न चालान है।

उदाहरण

इस उदाहरण में, हमें डेटा सेट करना होगा, 'एबीसी ग्राहक' रिकॉर्ड के रूप में नाम के साथ एक ग्राहक बनाना होगा और फिर उस ग्राहक के लिए 3 चालान जोड़ना होगा।

अब, हम ग्राहक के पास 'ABC' ग्राहक का चालान लाएंगे। इसके लिए क्वेरी निम्न है -

// Fetching Child Records using SOQL
List<apex_customer__c> ListCustomers = [SELECT Name, Id, 
   (SELECT id, Name FROM Invoices__r) FROM APEX_Customer__c WHERE Name = 'ABC Customer'];

// Query for fetching the Child records along with Parent
System.debug('ListCustomers '+ListCustomers); // Parent Record

List<apex_invoice__c> ListOfInvoices = ListCustomers[0].Invoices__r;
// By this notation, you could fetch the child records and save it in List
System.debug('ListOfInvoices values of Child '+ListOfInvoices);
// Child records

आप डिबग लॉग में रिकॉर्ड मान देख सकते हैं।

जनक अभिलेख प्राप्त करना

मान लीजिए, आपको इनवॉइस बनाने की तारीख का ग्राहक नाम लाने की आवश्यकता है, जो आज है, तो आप नीचे दिए गए क्वेरी का उपयोग उसी के लिए कर सकते हैं -

उदाहरण

चाइल्ड ऑब्जेक्ट के साथ पैरेंट रिकॉर्ड का मूल्य प्राप्त करें।

// Fetching Parent Record Field value using SOQL
List<apex_invoice__c> ListOfInvoicesWithCustomerName = new List<apex_invoice__c>();
ListOfInvoicesWithCustomerName = [SELECT Name, id, APEX_Customer__r.Name 
   FROM APEX_Invoice__c LIMIT 10];

// Fetching the Parent record's values
for (APEX_Invoice__c objInv: ListOfInvoicesWithCustomerName) {
   System.debug('Invoice Customer Name is '+objInv.APEX_Customer__r.Name);
   // Will print the values, all the Customer Records will be printed
}

यहां हमने नोटेशन APEX_Customer__r.Name का उपयोग किया है, जहां APEX_Customer__r माता-पिता का नाम है, यहां आपको मूल फ़ील्ड के अंत में __r को जोड़ना होगा और फिर आप पेरेंट फ़ील्ड मान प्राप्त कर सकते हैं।

अलग कार्य

SOQL का कुल कार्य है जैसा कि हमारे पास SQL ​​है। सकल कार्य हमें डेटा को रोल करने और सारांशित करने की अनुमति देते हैं। आइए अब फ़ंक्शन को विस्तार से समझते हैं।

मान लीजिए, आप जानना चाहते थे कि ग्राहक 'एबीसी ग्राहक' से हमें मिलने वाला औसत राजस्व क्या है, तो आप औसत लेने के लिए इस फ़ंक्शन का उपयोग कर सकते हैं।

उदाहरण

// Getting Average of all the invoices for a Perticular Customer
AggregateResult[] groupedResults = [SELECT
   AVG(APEX_Amount_Paid__c)averageAmount FROM APEX_Invoice__c WHERE
   APEX_Customer__r.Name = 'ABC Customer'];
Object avgPaidAmount = groupedResults[0].get('averageAmount');
System.debug('Total Average Amount Received From Customer ABC is '+avgPaidAmount);

डीबग लॉग में आउटपुट की जाँच करें। ध्यान दें कि किसी भी क्वेरी में एक समग्र फ़ंक्शन शामिल है, इसके परिणामों को एक सरणी में देता हैAggregateResultवस्तुओं। AggregateResult एक पठनीय sObject है और केवल क्वेरी परिणामों के लिए उपयोग किया जाता है। यह उपयोगी है जब हमें बड़े डेटा पर रिपोर्ट उत्पन्न करने की आवश्यकता होती है।

अन्य समग्र कार्य भी हैं जिनका उपयोग आप डेटा सारांश करने के लिए कर सकते हैं।

MIN() - इसका उपयोग न्यूनतम मान ज्ञात करने के लिए किया जा सकता है

MAX() - इसका उपयोग अधिकतम मूल्य खोजने के लिए किया जा सकता है।

बाइंडिंग एपेक्स वेरिएबल्स

वांछित परिणाम प्राप्त करने के लिए आप SOQL क्वेरी में एपेक्स चर का उपयोग कर सकते हैं। एपेक्स चर को बृहदान्त्र (:) संकेतन द्वारा संदर्भित किया जा सकता है।

उदाहरण

// Apex Variable Reference
String CustomerName = 'ABC Customer';
List<apex_customer__c> ListCustomer = [SELECT Id, Name FROM APEX_Customer__c
   WHERE Name = :CustomerName];

// Query Using Apex variable
System.debug('ListCustomer Name'+ListCustomer); // Customer Name