DocumentDB - क्वेरी दस्तावेज़

DocumentDB में, हम वास्तव में दस्तावेजों के लिए क्वेरी करने के लिए SQL का उपयोग करते हैं, इसलिए यह अध्याय DocumentDB में विशेष SQL सिंटैक्स का उपयोग करते हुए क्वेरी करने के बारे में है। यद्यपि यदि आप .NET विकास कर रहे हैं, तो एक LINQ प्रदाता भी है जिसका उपयोग किया जा सकता है और जो LINQ क्वेरी से उपयुक्त SQL उत्पन्न कर सकता है।

पोर्टल का उपयोग करके दस्तावेज़ को क्वेरी करना

Azure पोर्टल में एक क्वेरी एक्सप्लोरर है जिससे आप अपने DocumentDB डेटाबेस के खिलाफ कोई SQL क्वेरी चला सकते हैं।

हम क्वेरी एक्सप्लोरर का उपयोग सबसे सरल संभव क्वेरी से शुरू होने वाली क्वेरी भाषा की कई विभिन्न क्षमताओं और विशेषताओं को प्रदर्शित करने के लिए करेंगे।

Step 1 - डेटाबेस ब्लेड में, क्वेरी एक्सप्लोरर ब्लेड खोलने के लिए क्लिक करें।

याद रखें कि क्वेरी एक संग्रह के दायरे में चलती हैं, और इसलिए क्वेरी एक्सप्लोरर आपको इस ड्रॉपडाउन में संग्रह चुनने देता है।

Step 2 - परिवारों के संग्रह का चयन करें जो पहले पोर्टल का उपयोग करके बनाया गया है।

क्वेरी एक्सप्लोरर इस सरल क्वेरी SELECT * FROM c से खुलता है, जो संग्रह से सभी दस्तावेजों को पुनः प्राप्त करता है।

Step 3- 'रन क्वेरी' बटन पर क्लिक करके इस क्वेरी को निष्पादित करें। फिर आप देखेंगे कि परिणाम ब्लेड में पूरा दस्तावेज़ पुनर्प्राप्त किया गया है।

.Net SDK का उपयोग करके दस्तावेज़ को छोड़ना

.Net SDK का उपयोग करके कुछ डॉक्यूमेंट क्वेरीज़ को चलाने के लिए निम्नलिखित चरण हैं।

इस उदाहरण में, हम नए बनाए गए दस्तावेज़ों के लिए क्वेरी करना चाहते हैं जो हमने अभी जोड़े हैं।

Step 1 - कॉल CreateDocumentQuery, अपने SelfLink और क्वेरी पाठ के खिलाफ क्वेरी चलाने के लिए संग्रह में गुजर रहा है।

private async static Task QueryDocumentsWithPaging(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** Query Documents (paged results) ****"); 
   Console.WriteLine();  
   Console.WriteLine("Quering for all documents"); 
	
   var sql = "SELECT * FROM c";  
   var query = client.CreateDocumentQuery(collection.SelfLink, sql).AsDocumentQuery();
	
   while (query.HasMoreResults) {
      var documents = await query.ExecuteNextAsync(); 
		
      foreach (var document in documents) { 
         Console.WriteLine(" Id: {0}; Name: {1};", document.id, document.name); 
      } 
   }
	
   Console.WriteLine(); 
}

यह क्वेरी पूरे संग्रह में सभी दस्तावेज़ों को भी लौटा रही है, लेकिन हम कॉल नहीं कर रहे हैं। पहले की तरह CreateDocumentQuery पर .TLList करें, जो कोड के एक पंक्ति में सभी परिणामों को नीचे खींचने के लिए आवश्यक के रूप में कई अनुरोध जारी करेगा।

Step 2 - इसके बजाय, AsDocumentQuery को कॉल करें और यह विधि एक HasMoreResults संपत्ति के साथ एक क्वेरी ऑब्जेक्ट देता है।

Step 3 - अगर HasMoreResults सच है, तो अगले Chunk को प्राप्त करने के लिए ExecuteNextAsync को कॉल करें और फिर उस Chunk की सभी सामग्री को डंप करें।

Step 4- यदि आप चाहें तो SQL के बजाय LINQ का उपयोग करके क्वेरी भी कर सकते हैं। यहां हमने q में एक LINQ क्वेरी को परिभाषित किया है, लेकिन जब तक हम इसे नहीं चलाते तब तक यह निष्पादित नहीं होगा।

private static void QueryDocumentsWithLinq(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** Query Documents (LINQ) ****"); 
   Console.WriteLine();  
   Console.WriteLine("Quering for US customers (LINQ)");
	
   var q = 
      from d in client.CreateDocumentQuery<Customer>(collection.DocumentsLink) 
      where d.Address.CountryRegionName == " United States" 
      select new {
         Id = d.Id, 
         Name = d.Name, 
         City = d.Address.Location.City 
      };  
		
   var documents = q.ToList();  
   Console.WriteLine("Found {0} UK customers", documents.Count);
	
   foreach (var document in documents) {
      var d = document as dynamic; 
      Console.WriteLine(" Id: {0}; Name: {1}; City: {2}", d.Id, d.Name, d.City); 
   } 
	
   Console.WriteLine(); 
}

SDK डॉक्यूमेंटडीबी के लिए हमारी LINQ क्वेरी को SQL सिंटैक्स में परिवर्तित करेगा, जो हमारे वॉयस क्वैक्स के आधार पर एक SELECT और WHERE क्लॉज का निर्माण करेगा।

Step 5 - अब CreateDocumentClient कार्य से उपरोक्त प्रश्नों को कॉल करें।

private static async Task CreateDocumentClient() { 
   // Create a new instance of the DocumentClient 
	
   using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
      database = client.CreateDatabaseQuery("SELECT * FROM c WHERE c.id =
         'myfirstdb'").AsEnumerable().First(); 
			
      collection = client.CreateDocumentCollectionQuery(database.CollectionsLink,
         "SELECT * FROM c WHERE c.id = 'MyCollection'").AsEnumerable().First();  
			
      //await CreateDocuments(client); 
      await QueryDocumentsWithPaging(client); 
      QueryDocumentsWithLinq(client); 
   } 
	
}

जब उपरोक्त कोड निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा।

**** Query Documents (paged results) ****  
Quering for all documents 
 Id: 7e9ad4fa-c432-4d1a-b120-58fd7113609f; Name: New Customer 1; 
 Id: 34e9873a-94c8-4720-9146-d63fb7840fad; Name: New Customer 1;  
 
**** Query Documents (LINQ) **** 
Quering for US customers (LINQ) 
Found 2 UK customers 
 Id: 7e9ad4fa-c432-4d1a-b120-58fd7113609f; Name: New Customer 1; City: Brooklyn 
 Id: 34e9873a-94c8-4720-9146-d63fb7840fad; Name: New Customer 1; City: Brooklyn