DocumentDB - त्वरित गाइड

इस अध्याय में, हम संक्षेप में NoSQL और दस्तावेज़ डेटाबेस के आसपास की प्रमुख अवधारणाओं पर चर्चा करेंगे। हमारे पास DocumentDB का त्वरित अवलोकन भी होगा।

NoSQL दस्तावेज़ डेटाबेस

DocumentDB Microsoft का सबसे नया NoSQL डॉक्यूमेंट डेटाबेस है, इसलिए जब आप NoSQL डॉक्यूमेंट डेटाबेस को कहते हैं, तो हम NoSQL और दस्तावेज़ डेटाबेस से वास्तव में क्या मतलब रखते हैं?

  • SQL का मतलब स्ट्रक्चर्ड क्वेरी लैंग्वेज है जो रिलेशनल डेटाबेस की पारंपरिक क्वेरी लैंग्वेज है। SQL को अक्सर रिलेशनल डेटाबेस के साथ बराबर किया जाता है।

  • NoSQL डेटाबेस को एक गैर-संबंधपरक डेटाबेस के रूप में सोचना वास्तव में अधिक उपयोगी है, इसलिए NoSQL का वास्तव में गैर-संबंधपरक है।

NoSQL डेटाबेस के विभिन्न प्रकार हैं जिनमें प्रमुख मूल्य भंडार शामिल हैं जैसे -

  • एज़्योर टेबल स्टोरेज।
  • कैसंड्रा जैसे कॉलम-आधारित स्टोर।
  • NEO4 जैसे ग्राफ़ डेटाबेस।
  • दस्तावेज़ डेटाबेस जैसे MongoDB और Azure DocumentDB।

Azure DocumentDB

माइक्रोसॉफ्ट आधिकारिक तौर पर अप्रैल 8 पर Azure DocumentDB का शुभारंभ वें , 2015, और यह निश्चित रूप से एक ठेठ NoSQL दस्तावेज़ डेटाबेस विशेषता के रूप में किया जा सकता है। यह बड़े पैमाने पर स्केलेबल है, और यह स्कीमा मुक्त JSON दस्तावेजों के साथ काम करता है।

  • DocumentDB आधुनिक मोबाइल और वेब अनुप्रयोगों के लिए डिज़ाइन की गई एक सच्ची स्कीमा-रहित NoSQL दस्तावेज़ डेटाबेस सेवा है।

  • यह लगातार तेजी से पढ़ता है और लिखता है, स्कीमा लचीलापन, और आसानी से मांग पर डेटाबेस को ऊपर और नीचे पैमाने पर करने की क्षमता देता है।

  • यह JSON दस्तावेज़ों को अनुक्रमित करने के लिए किसी स्कीमा की आवश्यकता नहीं है या इसकी आवश्यकता नहीं है।

  • डॉक्यूमेंटडीबी डॉक्यूमेंट को डेटाबेस में जोड़ते ही डॉक्युमेंट में हर प्रॉपर्टी को अपने आप इंडेक्स कर देता है।

  • DocumentDB एक SQL भाषा का उपयोग करते हुए जटिल तदर्थ प्रश्नों को सक्षम करता है, और प्रत्येक दस्तावेज़ को उसके द्वारा बनाए गए पल को तुरंत क्वेरी किया जाता है, और आप दस्तावेज़ पदानुक्रम के भीतर कहीं भी किसी भी संपत्ति पर खोज कर सकते हैं।

DocumentDB - मूल्य निर्धारण

डॉक्यूमेंटडीबी एक डेटाबेस खाते में निहित संग्रह की संख्या के आधार पर बिल किया जाता है। प्रत्येक खाते में एक या अधिक डेटाबेस हो सकते हैं और प्रत्येक डेटाबेस में लगभग असीमित संख्या में संग्रह हो सकते हैं, हालांकि 100 का प्रारंभिक डिफ़ॉल्ट कोटा है। इस कोटा को Azure समर्थन से संपर्क करके उठाया जा सकता है।

  • एक संग्रह न केवल पैमाने की एक इकाई है, बल्कि लागत की एक इकाई भी है, इसलिए DocumentDB में आप प्रति संग्रह का भुगतान करते हैं, जिसमें 10 जीबी तक की भंडारण क्षमता है।

  • कम से कम, आपको डेटाबेस में दस्तावेज़ों को संग्रहीत करने के लिए एक एस 1 संग्रह की आवश्यकता होगी, जिसकी लागत लगभग $ 25 प्रति माह होगी, जो आपके एज़्योर सदस्यता के खिलाफ बिल हो जाता है।

  • जैसे ही आपका डेटाबेस आकार में बढ़ता है और 10 जीबी से अधिक हो जाता है, आपको अतिरिक्त डेटा सम्‍मिलित करने के लिए एक और संग्रह खरीदना होगा।

  • प्रत्येक S1 संग्रह आपको प्रति सेकंड 250 अनुरोध इकाइयाँ देगा, और यदि यह पर्याप्त नहीं है, तो आप संग्रह को S2 तक स्केल कर सकते हैं और प्रति माह लगभग $ 50 के लिए 1000 अनुरोध इकाइयाँ प्राप्त कर सकते हैं।

  • आप इसे S3 तक पूरा कर सकते हैं और प्रति माह लगभग 100 डॉलर का भुगतान कर सकते हैं।

DocumentDB कुछ बहुत ही अद्वितीय क्षमताओं के साथ बाहर खड़ा है। Azure DocumentDB निम्नलिखित प्रमुख क्षमताएं और लाभ प्रदान करता है।

स्कीमा मुफ्त

एक संबंधपरक डेटाबेस में, प्रत्येक तालिका में एक स्कीमा होता है जो स्तंभों और डेटा प्रकारों को परिभाषित करता है जो तालिका में प्रत्येक पंक्ति के अनुरूप होना चाहिए।

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

एसक्यूएल सिंटेक्स

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

ट्यून करने योग्य संगति

यह कुछ दानेदार, अच्छी तरह से परिभाषित स्थिरता स्तर प्रदान करता है, जो आपको स्थिरता, उपलब्धता और विलंबता के बीच ध्वनि व्यापार बंद करने की अनुमति देता है।

आप स्थिरता और प्रदर्शन के बीच इष्टतम व्यापार बंद को प्राप्त करने के लिए चार अच्छी तरह से परिभाषित स्थिरता स्तरों से चयन कर सकते हैं। प्रश्नों और पढ़ने के कार्यों के लिए, DocumentDB चार अलग-अलग स्थिरता स्तर प्रदान करता है -

  • Strong
  • Bounded-staleness
  • Session
  • Eventual

लोचदार स्केल

स्केलेबिलिटी NoSQL के साथ गेम का नाम है, और डॉक्यूमेंटडीबी डिलीवर करता है। DocumentDB पहले ही इसका पैमाना साबित हो चुका है।

  • Office OneNote और Xbox जैसी प्रमुख सेवाएँ पहले से ही DocumentDB द्वारा समर्थित हैं, जिसमें दसियों JSON दस्तावेज़ों के टेराबाइट्स शामिल हैं, एक लाख से अधिक सक्रिय उपयोगकर्ता हैं, और 99.95% उपलब्धता के साथ लगातार काम कर रहे हैं।

  • आप अपने अनुप्रयोग के बढ़ने पर अधिक इकाइयों का निर्माण करके अनुमानित प्रदर्शन के साथ DocumentDB को व्यापक रूप से बढ़ा सकते हैं।

पूरी तरह से प्रबंधित

DocumentDB, Azure पर चलने वाली सेवा के रूप में पूरी तरह से प्रबंधित क्लाउड-आधारित प्लेटफ़ॉर्म के रूप में उपलब्ध है।

  • आपको स्थापित करने या प्रबंधित करने के लिए बस कुछ नहीं है।

  • कोई सर्वर, केबल, कोई ऑपरेटिंग सिस्टम या अपडेट से निपटने के लिए सेट अप करने के लिए कोई प्रतिकृतियां नहीं हैं।

  • Microsoft वह सब काम करता है और सेवा चालू रखता है।

  • सचमुच मिनटों के भीतर, आप सिर्फ एक ब्राउज़र और एक एज़्योर सदस्यता का उपयोग करके DocumentDB के साथ काम करना शुरू कर सकते हैं।

Microsoft Visual Studio का एक निःशुल्क संस्करण प्रदान करता है जिसमें SQL सर्वर भी होता है और इसे डाउनलोड किया जा सकता है https://www.visualstudio.com

इंस्टालेशन

Step 1- एक बार डाउनलोडिंग पूरी हो जाने के बाद, इंस्टॉलर चलाएं। निम्नलिखित संवाद प्रदर्शित किया जाएगा।

Step 2 - इंस्टॉल बटन पर क्लिक करें और यह इंस्टॉलेशन प्रक्रिया शुरू कर देगा।

Step 3 - एक बार इंस्टॉलेशन प्रक्रिया सफलतापूर्वक पूरी हो जाने के बाद, आप निम्नलिखित संवाद देखेंगे।

Step 4 - इस संवाद को बंद करें और यदि आवश्यक हो तो अपने कंप्यूटर को पुनरारंभ करें।

Step 5- अब स्टार्ट मेनू से विजुअल स्टूडियो खोलें जो नीचे डायलॉग को खोलेगा। केवल तैयारी के लिए पहली बार कुछ समय लगेगा।

एक बार जब सब हो जाता है, तो आप विजुअल स्टूडियो की मुख्य विंडो देखेंगे।

Step 6 - फाइल → न्यू → प्रोजेक्ट से एक नया प्रोजेक्ट बनाते हैं।

Step 7 - कंसोल एप्लिकेशन का चयन करें, Name फ़ील्ड में DocumentDBDemo दर्ज करें और ओके बटन पर क्लिक करें।

Step 8 - समाधान एक्सप्लोरर में, अपनी परियोजना पर राइट-क्लिक करें।

Step 9 - प्रबंधित करें NuGet संकुल का चयन करें जो विज़ुअल स्टूडियो में निम्न विंडो खोलेगा और खोज ऑनलाइन इनपुट बॉक्स में, डॉक्यूमेंटीडीबी क्लाइंट लाइब्रेरी की खोज करेगा।

Step 10 - इंस्टॉल बटन पर क्लिक करके नवीनतम संस्करण स्थापित करें।

Step 11- "मैं स्वीकार करता हूं" पर क्लिक करें। एक बार इंस्टॉलेशन हो जाने के बाद आपको अपने आउटपुट विंडो में संदेश दिखाई देगा।

अब आप अपना आवेदन शुरू करने के लिए तैयार हैं।

Microsoft Azure DocumentDB का उपयोग करने के लिए, आपको एक DocumentDB खाता बनाना होगा। इस अध्याय में, हम एज़्योर पोर्टल का उपयोग करके एक डॉक्यूडीडीबी खाता बनाएंगे।

Step 1 - ऑनलाइन में लॉग इन करें https://portal.azure.com यदि आपके पास पहले से ही एक Azure सदस्यता है, तो आपको पहले साइन इन करने की आवश्यकता है।

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

Step 2 - पेज के ऊपर बाईं ओर 'नया' विकल्प चुनें।

Step 3 - अब Data + Storage> Azure DocumentDB विकल्प चुनें और आपको निम्न New DocumentDB खाता अनुभाग दिखाई देगा।

हमें विश्व स्तर पर अनूठे नाम (आईडी) के साथ आने की जरूरत है, जो .documents.azure.com के साथ संयुक्त रूप से हमारे DocumentDB खाते के लिए सार्वजनिक रूप से संबोधित करने योग्य समापन बिंदु है। हमारे द्वारा उस खाते के नीचे बनाए गए सभी डेटाबेस को इस समापन बिंदु का उपयोग करके इंटरनेट पर एक्सेस किया जा सकता है।

Step 4 - आइए इसे azuredocdbdemo नाम दें और संसाधन समूह → new_resource पर क्लिक करें।

Step 5- वह स्थान चुनें, जिसे आप चाहते हैं कि Microsoft डेटा केंद्र होस्ट किया जाए। स्थान का चयन करें और अपना क्षेत्र चुनें।

Step 6 - डैशबोर्ड चेकबॉक्स पर पिन चेक करें और बस आगे बढ़ें और क्रिएट बटन पर क्लिक करें।

आप देख सकते हैं कि टाइल को पहले ही डैशबोर्ड में जोड़ दिया गया है, और यह हमें बता रहा है कि खाता बनाया जा रहा है। नए खाते के लिए चीजों को सेट करने में वास्तव में कुछ मिनट लग सकते हैं जबकि डॉक्यूमेंटडीबी समापन बिंदु, प्रावधानों की प्रतिकृति, और पृष्ठभूमि में अन्य काम करता है।

एक बार यह हो जाने के बाद, आप डैशबोर्ड देखेंगे।

Step 7 - अब बने हुए DocumentDB अकाउंट पर क्लिक करें और आपको निम्न इमेज के रूप में एक विस्तृत स्क्रीन दिखाई देगी।

जब आप DocumentDB के खिलाफ प्रोग्रामिंग शुरू करते हैं, तो कनेक्ट करने के लिए पहला कदम है। तो अपने DocumentDB खाते से कनेक्ट करने के लिए आपको दो चीजों की आवश्यकता होगी;

  • Endpoint
  • प्राधिकरण कुंजी

endpoint

Endpoint आपके DocumentDB खाते का URL है और इसका निर्माण आपके DocumentDB खाते के नाम .documents.azure.com के साथ करके किया गया है। चलो डैशबोर्ड पर जाते हैं।

अब, Create DocumentDB अकाउंट पर क्लिक करें। आप नीचे दी गई छवि में दिखाए अनुसार विवरण देखेंगे।

जब आप 'कुंजी' विकल्प चुनते हैं, तो यह अतिरिक्त जानकारी प्रदर्शित करेगा जैसा कि निम्नलिखित छवि में दिखाया गया है। आपको अपने डॉक्यूमेंटीडीबी खाते का URL भी दिखाई देगा, जिसे आप अपने समापन बिंदु के रूप में उपयोग कर सकते हैं।

प्राधिकरण कुंजी

प्राधिकरण कुंजी में आपकी क्रेडेंशियल्स होते हैं और कुंजियाँ दो प्रकार की होती हैं। मास्टर कुंजी खाते के भीतर सभी संसाधनों तक पूर्ण पहुंच की अनुमति देती है, जबकि संसाधन टोकन विशिष्ट संसाधनों तक सीमित पहुंच की अनुमति देते हैं।

मास्टर कुंजी

  • मास्टर कुंजी के साथ ऐसा कुछ भी नहीं है जो आप नहीं कर सकते। आप मास्टर कुंजी का उपयोग करके अपने पूरे डेटाबेस को उड़ा सकते हैं।

  • इस कारण से, आप निश्चित रूप से मास्टर कुंजी साझा करना या क्लाइंट वातावरण में वितरित नहीं करना चाहते हैं। अतिरिक्त सुरक्षा उपाय के रूप में, इसे बार-बार बदलना एक अच्छा विचार है।

  • प्रत्येक डेटाबेस खाते के लिए वास्तव में दो मास्टर कुंजी हैं, उपरोक्त स्क्रीनशॉट में हाइलाइट किए गए अनुसार प्राथमिक और द्वितीयक।

संसाधन टोकन

  • आप मास्टर कुंजी के बजाय संसाधन टोकन का उपयोग कर सकते हैं।

  • संसाधन टोकन के आधार पर कनेक्शन केवल टोकन द्वारा निर्दिष्ट संसाधनों तक पहुंच सकते हैं और कोई अन्य संसाधन नहीं।

  • संसाधन टोकन उपयोगकर्ता अनुमतियों पर आधारित होते हैं, इसलिए पहले आप एक या अधिक उपयोगकर्ता बनाते हैं, और ये डेटाबेस स्तर पर परिभाषित होते हैं।

  • आप प्रत्येक उपयोगकर्ता के लिए एक या एक से अधिक अनुमतियाँ बनाते हैं, उन संसाधनों के आधार पर जिन्हें आप प्रत्येक उपयोगकर्ता तक पहुँचने की अनुमति देना चाहते हैं।

  • प्रत्येक अनुमति एक संसाधन टोकन उत्पन्न करती है जो किसी दिए गए संसाधन तक या तो केवल-पढ़ने या पूर्ण पहुँच की अनुमति देता है और डेटाबेस के भीतर कोई भी उपयोगकर्ता संसाधन हो सकता है।

चलो अध्याय 3 में बनाए गए कंसोल एप्लिकेशन पर जाएं।

Step 1 - Program.cs फ़ाइल में निम्न संदर्भ जोड़ें।

using Microsoft.Azure.Documents; 
using Microsoft.Azure.Documents.Client; 
using Microsoft.Azure.Documents.Linq; 
using Newtonsoft.Json;

Step 2- अब Endpoint URL और प्राधिकरण कुंजी जोड़ें। इस उदाहरण में हम प्राधिकरण कुंजी के रूप में प्राथमिक कुंजी का उपयोग करेंगे।

ध्यान दें कि आपके मामले में एंडपॉइंट URL और प्राधिकरण कुंजी दोनों अलग-अलग होनी चाहिए।

private const string EndpointUrl = "https://azuredocdbdemo.documents.azure.com:443/"; 
private const string AuthorizationKey = 
   "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";

Step 3 - CreateDocumentClient नामक अतुल्यकालिक कार्य में DocumentClient का एक नया उदाहरण बनाएं और नए DocumentClient को तुरंत लिखें।

Step 4 - अपने मुख्य विधि से अपने अतुल्यकालिक कार्य को बुलाओ।

निम्नलिखित अब तक का पूरा Program.cs फ़ाइल है।

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; 
using System.Threading.Tasks;

using Microsoft.Azure.Documents;
using Microsoft.Azure.Documents.Client;
using Microsoft.Azure.Documents.Linq;
using Newtonsoft.Json;

namespace DocumentDBDemo { 

   class Program {
      private const string EndpointUrl = "https://azuredocdbdemo.documents.azure.com:443/";
		
      private const string AuthorizationKey = "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/
         StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";
			
      static void Main(string[] args) {
         try {
            CreateDocumentClient().Wait();
         } catch (Exception e) {
            Exception baseException = e.GetBaseException();
            Console.WriteLine("Error: {0}, Message: {1}", e.Message, baseException.Message);
         }
			
         Console.ReadKey();
      }
		
      private static async Task CreateDocumentClient() {
         // Create a new instance of the DocumentClient
         var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey);
      }
		
   }
}

इस अध्याय में, हमने सीखा है कि डॉक्यूमेंटीडीबी खाते से कैसे जुड़ा जाए और डॉक्युमेंटक्लाइंट वर्ग का एक उदाहरण बनाया जाए।

इस अध्याय में, हम एक डेटाबेस बनाना सीखेंगे। Microsoft Azure DocumentDB का उपयोग करने के लिए, आपके पास एक DocumentDB खाता, एक डेटाबेस, एक संग्रह और दस्तावेज़ होना चाहिए। हमारे पास पहले से ही एक डॉक्यूडीडीबी खाता है, अब डेटाबेस बनाने के लिए हमारे पास दो विकल्प हैं -

  • Microsoft Azure पोर्टल या
  • .नेट SDK

Microsoft Azure पोर्टल का उपयोग करके DocumentDB के लिए एक डेटाबेस बनाएँ

पोर्टल का उपयोग करके एक डेटाबेस बनाने के लिए, निम्न चरण हैं।

Step 1 - एज़्योर पोर्टल पर लॉगइन करें और आपको डैशबोर्ड दिखाई देगा।

Step 2 - अब बने हुए डॉक्यूमेंट अकाउंट पर क्लिक करें और आपको नीचे स्क्रीनशॉट में दिखाए अनुसार विवरण दिखाई देगा।

Step 3 - डेटाबेस जोड़ें विकल्प चुनें और अपने डेटाबेस के लिए आईडी प्रदान करें।

Step 4 - क्लिक करें।

आप देख सकते हैं कि डेटाबेस जोड़ा गया है। फिलहाल, इसका कोई संग्रह नहीं है, लेकिन हम बाद में संग्रह जोड़ सकते हैं जो कंटेनर हैं जो हमारे JSON दस्तावेजों को संग्रहीत करेंगे। ध्यान दें कि इसमें एक आईडी और एक संसाधन आईडी दोनों हैं।

.Net SDK का उपयोग कर डॉक्यूमेंटडीबी के लिए एक डेटाबेस बनाएँ

.Net SDK का उपयोग करके एक डेटाबेस बनाने के लिए, निम्न चरण हैं।

Step 1 - अंतिम अध्याय से विज़ुअल स्टूडियो में कंसोल एप्लिकेशन खोलें।

Step 2- नया डेटाबेस ऑब्जेक्ट बनाकर नया डेटाबेस बनाएं। एक नया डेटाबेस बनाने के लिए, हमें केवल Id प्रॉपर्टी असाइन करनी होगी, जिसे हम CreateDatabase कार्य में "mynewdb" पर सेट कर रहे हैं।

private async static Task CreateDatabase(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("******** Create Database *******");
	
   var databaseDefinition = new Database { Id = "mynewdb" }; 
   var result = await client.CreateDatabaseAsync(databaseDefinition); 
   var database = result.Resource;
	
   Console.WriteLine(" Database Id: {0}; Rid: {1}", database.Id, database.ResourceId); 
   Console.WriteLine("******** Database Created *******"); 
}

Step 3- अब CreateDatabaseAsync पर इस डेटाबेसडिफिनेशन को पास करें, और रिसोर्स प्रॉपर्टी के साथ रिजल्ट प्राप्त करें। ऑब्जेक्ट बनाने वाली सभी विधियाँ एक संसाधन गुण लौटाती हैं जो उस आइटम का वर्णन करता है जो बनाया गया था, जो इस मामले में एक डेटाबेस है।

हमें संसाधन डेटाबेस से नया डेटाबेस ऑब्जेक्ट मिलता है और यह कंसोल पर संसाधन आईडी के साथ प्रदर्शित होता है जिसे डॉक्यूमेंटीडीबी ने सौंपा है।

Step 4 - अब CreateDocumentClient कार्य से CreateDatabase कार्य को DocumentClient के तुरंत बाद कॉल करें।

using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) { 
   await CreateDatabase(client); 
}

निम्नलिखित अब तक का पूरा Program.cs फ़ाइल है।

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using Microsoft.Azure.Documents;
using Microsoft.Azure.Documents.Client;
using Microsoft.Azure.Documents.Linq;
using Newtonsoft.Json;

namespace DocumentDBDemo {

   class Program {
      private const string EndpointUrl = "https://azuredocdbdemo.documents.azure.com:443/";
		
      private const string AuthorizationKey = "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/
         StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";
			
      static void Main(string[] args) {
         try {
            CreateDocumentClient().Wait();
         } catch (Exception e) {
            Exception baseException = e.GetBaseException();
            Console.WriteLine("Error: {0}, Message: {1}", e.Message, baseException.Message);
         }
         Console.ReadKey();
      }
		
      private static async Task CreateDocumentClient() {
         // Create a new instance of the DocumentClient
         using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
            await CreateDatabase(client);
         } 
      }
		
      private async static Task CreateDatabase(DocumentClient client) {
         Console.WriteLine();
         Console.WriteLine("******** Create Database *******");
			
         var databaseDefinition = new Database { Id = "mynewdb" };
         var result = await client.CreateDatabaseAsync(databaseDefinition);
         var database = result.Resource;
			
         Console.WriteLine(" Database Id: {0}; Rid: {1}", database.Id, database.ResourceId);
         Console.WriteLine("******** Database Created *******");
      }
		
   } 
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा जिसमें डेटाबेस और संसाधन आईडी शामिल हैं।

******** Create Database ******* 
 Database Id: mynewdb; Rid: ltpJAA== 
******** Database Created *******

अब तक, हमने अपने DocumentDB खाते में दो डेटाबेस बनाए हैं, पहला एक Azure पोर्टल का उपयोग करके बनाया गया है जबकि दूसरा डेटाबेस .Net का उपयोग करके बनाया गया है। अब इन डेटाबेस को देखने के लिए, आप Azure पोर्टल का उपयोग कर सकते हैं।

Azure पोर्टल पर अपने DocumentDB खाते में जाएं और अब आपको दो डेटाबेस दिखाई देंगे।

.Net SDK का उपयोग करके आप अपने कोड से डेटाबेस को देख या सूचीबद्ध भी कर सकते हैं। निम्नलिखित कदम शामिल हैं।

Step 1 - एक डेटाबेस क्वेरी जारी करें जिसमें कोई पैरामीटर नहीं है जो पूरी सूची देता है, लेकिन आप किसी विशिष्ट डेटाबेस या विशिष्ट डेटाबेस की तलाश करने के लिए क्वेरी में भी पास कर सकते हैं।

private static void GetDatabases(DocumentClient client) {
   Console.WriteLine();
   Console.WriteLine();
   Console.WriteLine("******** Get Databases List ********");
	
   var databases = client.CreateDatabaseQuery().ToList(); 
	
   foreach (var database in databases) { 
      Console.WriteLine(" Database Id: {0}; Rid: {1}", database.Id, database.ResourceId);
   }
	
   Console.WriteLine(); 
   Console.WriteLine("Total databases: {0}", databases.Count);
}

आप देखेंगे कि संग्रह, दस्तावेज़, उपयोगकर्ता और अन्य संसाधनों का पता लगाने के लिए इन CreateQuery विधियों का एक समूह है। ये विधियां वास्तव में क्वेरी को निष्पादित नहीं करती हैं, वे सिर्फ क्वेरी को परिभाषित करती हैं और एक पुनरावृत्त वस्तु को वापस करती हैं।

यह ToList () के लिए कॉल है जो वास्तव में क्वेरी को निष्पादित करता है, परिणामों को पुनरावृत्त करता है, और उन्हें एक सूची में वापस करता है।

Step 2 डॉक्युमेंटक्लाइंट के तुरंत बाद CreateDocumentClient कार्य से गेटडेट डेटाबेस विधि को कॉल करें।

Step 3 - आपको CreateDatabase के कार्य पर भी टिप्पणी करनी होगी या डेटाबेस आईडी को बदलना होगा, अन्यथा आपको एक त्रुटि संदेश मिलेगा कि डेटाबेस मौजूद है।

using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
   //await CreateDatabase(client); 
   GetDatabases(client); 
}

निम्नलिखित अब तक का पूरा Program.cs फ़ाइल है।

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using Microsoft.Azure.Documents;
using Microsoft.Azure.Documents.Client;
using Microsoft.Azure.Documents.Linq;
using Newtonsoft.Json; 

namespace DocumentDBDemo {

   class Program {
      private const string EndpointUrl = "https://azuredocdbdemo.documents.azure.com:443/";
		
      private const string AuthorizationKey = "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/
         StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";
			
      static void Main(string[] args) {
         try {
            CreateDocumentClient().Wait();
         } catch (Exception e) {
            Exception baseException = e.GetBaseException();
            Console.WriteLine("Error: {0}, Message: {1}", e.Message, baseException.Message);
         }
         Console.ReadKey();
      }
		
      private static async Task CreateDocumentClient() {
         // Create a new instance of the DocumentClient
         using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
            await CreateDatabase(client);
            GetDatabases(client);
         } 
      }
		
      private async static Task CreateDatabase(DocumentClient client) {
         Console.WriteLine();
         Console.WriteLine("******** Create Database *******");
			
         var databaseDefinition = new Database { Id = "mynewdb" };
         var result = await client.CreateDatabaseAsync(databaseDefinition);
         var database = result.Resource;
			
         Console.WriteLine(" Database Id: {0}; Rid: {1}", database.Id, database.ResourceId);
         Console.WriteLine("******** Database Created *******");
      }
		
      private static void GetDatabases(DocumentClient client) {
         Console.WriteLine();
         Console.WriteLine();
         Console.WriteLine("******** Get Databases List ********");
			
         var databases = client.CreateDatabaseQuery().ToList();
			
         foreach (var database in databases) {
            Console.WriteLine(" Database Id: {0}; Rid: {1}",
               database.Id, database.ResourceId);
         }  
			
         Console.WriteLine(); 
         Console.WriteLine("Total databases: {0}", databases.Count);
      }
		
   } 
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा जिसमें डेटाबेस और संसाधन दोनों डेटाबेस के आईडी शामिल हैं। अंत में आप कुल डेटाबेस की संख्या भी देखेंगे।

******** Get Databases List ******** 
 Database Id: myfirstdb; Rid: Ic8LAA== 
 Database Id: mynewdb; Rid: ltpJAA==  
Total databases: 2

आप .net SDK का उपयोग करके एक डेटाबेस या डेटाबेस को पोर्टल से और साथ ही कोड से ड्रॉप कर सकते हैं। यहां, हम एक कदम-वार तरीके से चर्चा करेंगे, कि डॉक्यूमेंटडीबी में एक डेटाबेस को कैसे छोड़ा जाए।

Step 1- Azure पोर्टल पर अपने DocumentDB खाते में जाएं। डेमो के उद्देश्य के लिए, मैंने दो और डेटाबेस जोड़े हैं जैसा कि निम्नलिखित स्क्रीनशॉट में देखा गया है।

Step 2- किसी भी डेटाबेस को छोड़ने के लिए, आपको उस डेटाबेस पर क्लिक करना होगा। चलो tempdb का चयन करें, आप निम्न पृष्ठ देखेंगे, 'डिलीट डेटाबेस' विकल्प चुनें।

Step 3 - यह पुष्टि संदेश प्रदर्शित करेगा, अब 'हां' बटन पर क्लिक करें।

आप देखेंगे कि आपके डैशबोर्ड में tempdb उपलब्ध नहीं है।

आप .net SDK का उपयोग करके अपने कोड से डेटाबेस भी हटा सकते हैं। निम्नलिखित करने के लिए चरण हैं।

Step 1 - हम उस डेटाबेस की आईडी निर्दिष्ट करके डेटाबेस को हटाते हैं जिसे हम हटाना चाहते हैं, लेकिन हमें इसके सेल्फलिंक की आवश्यकता है।

Step 2 - हम पहले की तरह CreateDatabaseQuery को कॉल कर रहे हैं, लेकिन इस बार हम वास्तव में आईडी tempdb1 के साथ सिर्फ एक डेटाबेस को वापस करने के लिए एक क्वेरी की आपूर्ति कर रहे हैं।

private async static Task DeleteDatabase(DocumentClient client) {
   Console.WriteLine("******** Delete Database ********");
   Database database = client
      .CreateDatabaseQuery("SELECT * FROM c WHERE c.id = 'tempdb1'")
      .AsEnumerable()
      .First();
   await client.DeleteDatabaseAsync(database.SelfLink);
}

Step 3- इस बार, हम ToList () के बजाय AsEnumerable को कॉल कर सकते हैं क्योंकि हमें वास्तव में सूची ऑब्जेक्ट की आवश्यकता नहीं है। केवल परिणाम की उम्मीद करते हुए, AsEnumerable को कॉल करना पर्याप्त है ताकि हम First () के साथ क्वेरी द्वारा लौटाया गया पहला डेटाबेस ऑब्जेक्ट प्राप्त कर सकें। यह tempdb1 के लिए डेटाबेस ऑब्जेक्ट है और इसमें एक SelfLink है जिसे हम DeleteDatabaseAsync को कॉल करने के लिए उपयोग कर सकते हैं जो डेटाबेस को हटा देता है।

Step 4 - डॉक्यूमेंट क्लियर होने के बाद आपको CreateDocumentClient कार्य से DeleteDatabase कार्य को भी कॉल करना होगा।

Step 5 - निर्दिष्ट डेटाबेस को हटाने के बाद डेटाबेस की सूची को देखने के लिए, GetDat डेटाबेस विधि को फिर से कॉल करें।

using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
   //await CreateDatabase(client);
	
   GetDatabases(client);
   await DeleteDatabase(client);
   GetDatabases(client); 
}

निम्नलिखित अब तक का पूरा Program.cs फ़ाइल है।

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using Microsoft.Azure.Documents;
using Microsoft.Azure.Documents.Client;
using Microsoft.Azure.Documents.Linq;
using Newtonsoft.Json;

namespace DocumentDBDemo {

   class Program {
	
      private const string EndpointUrl = "https://azuredocdbdemo.documents.azure.com:443/";
		
      private const string AuthorizationKey = "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/
         StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";
			
      static void Main(string[] args) {
         try {
            CreateDocumentClient().Wait();
         } catch (Exception e) {
            Exception baseException = e.GetBaseException();
            Console.WriteLine("Error: {0}, Message: {1}", e.Message, baseException.Message);
         }
         Console.ReadKey();
      }
		
      private static async Task CreateDocumentClient() {
         // Create a new instance of the DocumentClient
         using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
            //await CreateDatabase(client);
            GetDatabases(client);
            await DeleteDatabase(client);
            GetDatabases(client);
         }
      }
		
      private async static Task CreateDatabase(DocumentClient client) {
         Console.WriteLine();
         Console.WriteLine("******** Create Database *******");
			
         var databaseDefinition = new Database { Id = "mynewdb" };
         var result = await client.CreateDatabaseAsync(databaseDefinition);
         var database = result.Resource;
			
         Console.WriteLine(" Database Id: {0}; Rid: {1}",
            database.Id, database.ResourceId);
         Console.WriteLine("******** Database Created *******");
      }
		
      private static void GetDatabases(DocumentClient client) {
         Console.WriteLine();
         Console.WriteLine();
         Console.WriteLine("******** Get Databases List ********");
			
         var databases = client.CreateDatabaseQuery().ToList();
			
         foreach (var database in databases) {
            Console.WriteLine(" Database Id: {0}; Rid: {1}", database.Id,
               database.ResourceId);
         }
			
         Console.WriteLine();
         Console.WriteLine("Total databases: {0}", databases.Count);
      }
		
      private async static Task DeleteDatabase(DocumentClient client) {
         Console.WriteLine();
         Console.WriteLine("******** Delete Database ********");
			
         Database database = client
            .CreateDatabaseQuery("SELECT * FROM c WHERE c.id = 'tempdb1'")
            .AsEnumerable()
            .First();
         await client.DeleteDatabaseAsync(database.SelfLink);
      }
		
   }
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा जिसमें तीन डेटाबेस के डेटाबेस और संसाधन आईडी और कुल डेटाबेस की संख्या शामिल है।

******** Get Databases List ******** 
 Database Id: myfirstdb; Rid: Ic8LAA== 
 Database Id: mynewdb; Rid: ltpJAA== 
 Database Id: tempdb1; Rid: 06JjAA==
 
Total databases: 3  

******** Delete Database ******** 
  
******** Get Databases List ******** 
 Database Id: myfirstdb; Rid: Ic8LAA== 
 Database Id: mynewdb; Rid: ltpJAA==
 
Total databases: 2

डेटाबेस को हटाने के बाद, आप अंत में यह भी देखेंगे कि केवल दो डेटाबेस ही डॉक्यूमेंटडीबी खाते में बचे हैं।

इस अध्याय में, हम सीखेंगे कि एक संग्रह कैसे बनाया जाए। यह एक डेटाबेस बनाने के समान है। आप .net SDK का उपयोग करके या तो पोर्टल से या कोड से एक संग्रह बना सकते हैं।

Step 1 - एज़्योर पोर्टल पर मुख्य डैशबोर्ड पर जाएं।

Step 2 - डेटाबेस सूची से myfirstdb का चयन करें।

Step 3- 'एड कलेक्शन' विकल्प पर क्लिक करें और संग्रह के लिए आईडी निर्दिष्ट करें। अलग-अलग विकल्प के लिए मूल्य निर्धारण स्तर चुनें।

Step 4 - चलो S1 स्टैंडर्ड चुनें और Select → OK बटन पर क्लिक करें।

जैसा कि आप देख सकते हैं कि MyCollection को myfirstdb में जोड़ा जाता है।

आप .Net SDK का उपयोग करके कोड से संग्रह भी बना सकते हैं। कोड से संग्रह जोड़ने के लिए निम्न चरणों पर एक नजर डालते हैं।

Step 1 - विजुअल स्टूडियो में कंसोल एप्लिकेशन खोलें।

Step 2 - एक संग्रह बनाने के लिए, पहले CreateDocumentClient कार्य में अपनी आईडी द्वारा myfirstdb डेटाबेस को पुनः प्राप्त करें।

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();
			
      await CreateCollection(client, "MyCollection1");
      await CreateCollection(client, "MyCollection2", "S2"); 
   }
}

निम्नलिखित CreateCollection कार्य के लिए कार्यान्वयन है।

private async static Task CreateCollection(DocumentClient client, string collectionId,
   string offerType = "S1") {
	
   Console.WriteLine();
   Console.WriteLine("**** Create Collection {0} in {1} ****", collectionId, database.Id);
	
   var collectionDefinition = new DocumentCollection { Id = collectionId };
   var options = new RequestOptions { OfferType = offerType };
   var result = await client.CreateDocumentCollectionAsync(database.SelfLink,
      collectionDefinition, options);
   var collection = result.Resource;
	
   Console.WriteLine("Created new collection");
   ViewCollection(collection);
}

हम एक नया DocumentCollection ऑब्जेक्ट बनाते हैं जो CreateDocumentCollectionAsync विधि के लिए वांछित आईडी के साथ नए संग्रह को परिभाषित करता है, जो एक विकल्प पैरामीटर को भी स्वीकार करता है जिसे हम नए संग्रह के प्रदर्शन स्तर को सेट करने के लिए यहां उपयोग कर रहे हैं, जो ऑफ़रटाइप कह रहा है।

यह S1 के लिए डिफॉल्ट करता है और चूंकि हम MyCollection1 के लिए एक ऑफ़र टाइप में पास नहीं हुए हैं, इसलिए यह S1 का कलेक्शन होगा और MyCollection2 के लिए हमने S2 पास किया है जो कि ऊपर दिखाए गए अनुसार इस S2 को बनाते हैं।

निम्नलिखित ViewCollection विधि का कार्यान्वयन है।

private static void ViewCollection(DocumentCollection collection) {
   Console.WriteLine("Collection ID: {0} ", collection.Id); 
   Console.WriteLine("Resource ID: {0} ", collection.ResourceId); 
   Console.WriteLine("Self Link: {0} ", collection.SelfLink); 
   Console.WriteLine("Documents Link: {0} ", collection.DocumentsLink); 
   Console.WriteLine("UDFs Link: {0} ", collection.UserDefinedFunctionsLink); 
   Console.WriteLine(" StoredProcs Link: {0} ", collection.StoredProceduresLink); 
   Console.WriteLine("Triggers Link: {0} ", collection.TriggersLink); 
   Console.WriteLine("Timestamp: {0} ", collection.Timestamp);
}

संग्रह के लिए program.cs फ़ाइल का पूर्ण कार्यान्वयन निम्नलिखित है।

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using Microsoft.Azure.Documents;
using Microsoft.Azure.Documents.Client;
using Microsoft.Azure.Documents.Linq;

using Newtonsoft.Json;

namespace DocumentDBDemo {

   class Program {
	
      private const string EndpointUrl = "https://azuredocdbdemo.documents.azure.com:443/";
		
      private const string AuthorizationKey = "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/
         StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";
			
      private static Database database;
		
      static void Main(string[] args) {
         try {
            CreateDocumentClient().Wait();
         } catch (Exception e) {
            Exception baseException = e.GetBaseException();
            Console.WriteLine("Error: {0}, Message: {1}", e.Message, baseException.Message);
         }
         Console.ReadKey();
      }
		
      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();
            await CreateCollection(client, "MyCollection1");
            await CreateCollection(client, "MyCollection2", "S2");
				
            //await CreateDatabase(client);
            //GetDatabases(client);
            //await DeleteDatabase(client);
            //GetDatabases(client);
         }
      }
		
      private async static Task CreateCollection(DocumentClient client,
         string collectionId, string offerType = "S1") {
			
         Console.WriteLine();
         Console.WriteLine("**** Create Collection {0} in {1} ****", collectionId,
            database.Id);

         var collectionDefinition = new DocumentCollection { Id = collectionId };
         var options = new RequestOptions { OfferType = offerType };
         var result = await 
			
			client.CreateDocumentCollectionAsync(database.SelfLink,
            collectionDefinition, options);
         var collection = result.Resource;

         Console.WriteLine("Created new collection");
         ViewCollection(collection);
      }
		
      private static void ViewCollection(DocumentCollection collection) {
         Console.WriteLine("Collection ID: {0} ", collection.Id);
         Console.WriteLine("Resource ID: {0} ", collection.ResourceId);
         Console.WriteLine("Self Link: {0} ", collection.SelfLink);
         Console.WriteLine("Documents Link: {0} ", collection.DocumentsLink);
         Console.WriteLine("UDFs Link: {0} ", collection.UserDefinedFunctionsLink);
         Console.WriteLine("StoredProcs Link: {0} ", collection.StoredProceduresLink);
         Console.WriteLine("Triggers Link: {0} ", collection.TriggersLink);
         Console.WriteLine("Timestamp: {0} ", collection.Timestamp);
      }
		
   }
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होंगे जिसमें संग्रह से संबंधित सभी जानकारी होगी।

**** Create Collection MyCollection1 in myfirstdb **** 
Created new collection
   Collection ID: MyCollection1
      Resource ID: Ic8LAPPvnAA=
         Self Link: dbs/Ic8LAA==/colls/Ic8LAPPvnAA=/
   Documents Link: dbs/Ic8LAA==/colls/Ic8LAPPvnAA=/docs/
         UDFs Link: dbs/Ic8LAA==/colls/Ic8LAPPvnAA=/udfs/
   StoredProcs Link: dbs/Ic8LAA==/colls/Ic8LAPPvnAA=/sprocs/
      Triggers Link: dbs/Ic8LAA==/colls/Ic8LAPPvnAA=/triggers/
         Timestamp: 12/10/2015 4:55:36 PM
		  
**** Create Collection MyCollection2 in myfirstdb ****
Created new collection
   Collection ID: MyCollection2
      Resource ID: Ic8LAKGHDwE=
         Self Link: dbs/Ic8LAA==/colls/Ic8LAKGHDwE=/
   Documents Link: dbs/Ic8LAA==/colls/Ic8LAKGHDwE=/docs/
         UDFs Link: dbs/Ic8LAA==/colls/Ic8LAKGHDwE=/udfs/
   StoredProcs Link: dbs/Ic8LAA==/colls/Ic8LAKGHDwE=/sprocs/
      Triggers Link: dbs/Ic8LAA==/colls/Ic8LAKGHDwE=/triggers/
         Timestamp: 12/10/2015 4:55:38 PM

संग्रह या संग्रह को छोड़ने के लिए आप .net SDK का उपयोग करके पोर्टल से और साथ ही कोड से भी कर सकते हैं।

Step 1- Azure पोर्टल पर अपने DocumentDB खाते में जाएं। डेमो के उद्देश्य के लिए, मैंने दो और संग्रह जोड़े हैं जैसा कि निम्नलिखित स्क्रीनशॉट में देखा गया है।

Step 2- किसी भी संग्रह को छोड़ने के लिए, आपको उस संग्रह पर क्लिक करना होगा। चलो TempCollection1 का चयन करें। आपको निम्न पेज दिखाई देगा, 'डिलीट कलेक्शन' विकल्प चुनें।

Step 3- यह पुष्टि संदेश प्रदर्शित करेगा। अब 'यस ’बटन पर क्लिक करें।

आप देखेंगे कि TempCollection1 आपके डैशबोर्ड पर अधिक उपलब्ध नहीं है।

आप .Net SDK का उपयोग करके अपने कोड से संग्रह भी हटा सकते हैं। ऐसा करने के लिए, निम्नलिखित कदम हैं।

Step 1 - जिस कलेक्शन को हम डिलीट करना चाहते हैं, उसकी आईडी बताकर कलेक्शन को डिलीट कर दें।

किसी संसाधन को हटाने के लिए आवश्यक SelfLinks प्राप्त करने के लिए Id द्वारा क्वेरी करना सामान्य पैटर्न है।

private async static Task DeleteCollection(DocumentClient client, string collectionId) {
   Console.WriteLine();
   Console.WriteLine("**** Delete Collection {0} in {1} ****", collectionId, database.Id);
	
   var query = new SqlQuerySpec {
      QueryText = "SELECT * FROM c WHERE c.id = @id",
         Parameters = new SqlParameterCollection {
         new SqlParameter {
            Name = "@id", Value = collectionId
         }
      }
   };
	
   DocumentCollection collection = client.CreateDocumentCollectionQuery(database.SelfLink,
      query).AsEnumerable().First();
		
   await client.DeleteDocumentCollectionAsync(collection.SelfLink);
   Console.WriteLine("Deleted collection {0} from database {1}", collectionId,
      database.Id);
}

यहां हम एक पैरामीटर क्वेरी के निर्माण का पसंदीदा तरीका देखते हैं। हम संग्रह को हार्डकोड नहीं कर रहे हैं, इसलिए इस विधि का उपयोग किसी भी संग्रह को हटाने के लिए किया जा सकता है। हम आईडी द्वारा एक विशिष्ट संग्रह के लिए क्वेरी कर रहे हैं जहां आईडी पैरामीटर इस SqlParameterCollection में परिभाषित किया गया है जो इस SqlQuerySpec के पैरामीटर की संपत्ति को सौंपा गया है।

तब एसडीके डॉक्यूमेंटडीबी के लिए अंतिम क्वेरी स्ट्रिंग के निर्माण का काम करता है, इसके अंदर संग्रहित आईडीआई के साथ।

Step 2 - क्वेरी चलाएँ और फिर CreateDocumentClient कार्य से संग्रह को हटाने के लिए इसके SelfLink का उपयोग करें।

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(); 
      await DeleteCollection(client, "TempCollection"); 
   } 
}

निम्नलिखित Program.cs फ़ाइल का पूर्ण कार्यान्वयन है।

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using Microsoft.Azure.Documents;
using Microsoft.Azure.Documents.Client;
using Microsoft.Azure.Documents.Linq;

using Newtonsoft.Json;

namespace DocumentDBDemo {

   class Program {
	
      private const string EndpointUrl = "https://azuredocdbdemo.documents.azure.com:443/";
		
      private const string AuthorizationKey = "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/
         StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";
			
      private static Database database;

      static void Main(string[] args) {
         try {
            CreateDocumentClient().Wait();
         } catch (Exception e) {
            Exception baseException = e.GetBaseException();
            Console.WriteLine("Error: {0}, Message: {1}", e.Message, baseException.Message);
         }
         Console.ReadKey();
      }

      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();
            await DeleteCollection(client, "TempCollection");
				
            //await CreateCollection(client, "MyCollection1");
            //await CreateCollection(client, "MyCollection2", "S2");
            ////await CreateDatabase(client);
            //GetDatabases(client);
            //await DeleteDatabase(client);
            //GetDatabases(client);
         }
      }
		
      private async static Task CreateCollection(DocumentClient client,
         string collectionId, string offerType = "S1") {
			
         Console.WriteLine();
         Console.WriteLine("**** Create Collection {0} in {1} ****", collectionId,
            database.Id);
         
         var collectionDefinition = new DocumentCollection { Id = collectionId };
         var options = new RequestOptions { OfferType = offerType };
         var result = await client.CreateDocumentCollectionAsync(database.SelfLink,
            collectionDefinition, options);
				
         var collection = result.Resource; 
         
         Console.WriteLine("Created new collection"); 
         ViewCollection(collection); 
      }

      private static void ViewCollection(DocumentCollection collection) {
         Console.WriteLine("Collection ID: {0} ", collection.Id); 
         Console.WriteLine("Resource ID: {0} ", collection.ResourceId); 
         Console.WriteLine("Self Link: {0} ", collection.SelfLink); 
         Console.WriteLine("Documents Link: {0} ", collection.DocumentsLink); 
         Console.WriteLine("UDFs Link: {0} ", collection.UserDefinedFunctionsLink); 
         Console.WriteLine("StoredProcs Link: {0} ", collection.StoredProceduresLink); 
         Console.WriteLine("Triggers Link: {0} ", collection.TriggersLink); 
         Console.WriteLine("Timestamp: {0} ", collection.Timestamp); 
      }
		
      private async static Task DeleteCollection(DocumentClient client,
         string collectionId) {
			
         Console.WriteLine();
         Console.WriteLine("**** Delete Collection {0} in {1} ****", collectionId,
            database.Id);
				
         var query = new SqlQuerySpec {
            QueryText = "SELECT * FROM c WHERE c.id = @id", Parameters = new
               SqlParameterCollection {
               new SqlParameter {
                  Name = "@id", Value = collectionId
               }
            }
         };
			
         DocumentCollection collection = client.CreateDocumentCollectionQuery
            (database.SelfLink, query).AsEnumerable().First();
				
         await client.DeleteDocumentCollectionAsync(collection.SelfLink);
         Console.WriteLine("Deleted collection {0} from database {1}", collectionId,
            database.Id); 
      }
		
   } 
}

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

**** Delete Collection TempCollection in myfirstdb **** 
Deleted collection TempCollection from database myfirstdb

इस अध्याय में, हमें एक संग्रह में वास्तविक दस्तावेजों के साथ काम करना होगा। आप Azure पोर्टल या .Net SDK का उपयोग करके दस्तावेज़ बना सकते हैं।

Azure पोर्टल के साथ दस्तावेज़ बनाना

अपने संग्रह में दस्तावेज़ जोड़ने के लिए निम्नलिखित चरणों पर एक नज़र डालते हैं।

Step 1 - myfirstdb में S1 प्राइसिंग टियर के नए कलेक्शन परिवारों को जोड़ें।

Step 2 - परिवार संग्रह का चयन करें और नया दस्तावेज़ ब्लेड खोलने के लिए दस्तावेज़ बनाएँ विकल्प पर क्लिक करें।

यह सिर्फ एक साधारण टेक्स्ट एडिटर है जो आपको किसी नए दस्तावेज़ के लिए JSON टाइप करने की सुविधा देता है।

Step 3 - यह कच्चे डेटा प्रविष्टि के रूप में है, चलो हमारे पहले दस्तावेज़ दर्ज करें।

{
   "id": "AndersenFamily", 
   "lastName": "Andersen", 
	
   "parents": [ 
      { "firstName": "Thomas", "relationship": "father" }, 
      { "firstName": "Mary Kay", "relationship": "mother" } 
   ], 
	
   "children": [ 
      { 
         "firstName": "Henriette Thaulow", 
         "gender": "female", 
         "grade": 5, 
         "pets": [ { "givenName": "Fluffy", "type": "Rabbit" } ] 
      } 
   ], 
	
   "location": { "state": "WA", "county": "King", "city": "Seattle"}, 
   "isRegistered": true
}

जब आप उपरोक्त दस्तावेज़ दर्ज करते हैं, तो आपको निम्न स्क्रीन दिखाई देगी।

ध्यान दें कि हमने दस्तावेज़ के लिए एक आईडी प्रदान की है। आईडी मान की हमेशा आवश्यकता होती है, और यह एक ही संग्रह में अन्य सभी दस्तावेजों में अद्वितीय होना चाहिए। जब आप इसे छोड़ देते हैं, तो आपके लिए GUID या ग्लोबली यूनिक आइडेंटिफायर का उपयोग करके DocumentDB अपने आप एक उत्पन्न कर देगा।

आईडी हमेशा एक स्ट्रिंग है और यह एक संख्या, दिनांक, बूलियन, या अन्य ऑब्जेक्ट नहीं हो सकता है, और यह 255 वर्णों से अधिक लंबा नहीं हो सकता है।

दस्तावेज़ के पदानुक्रम संरचना को भी नोटिस करें, जिसमें आवश्यक आईडी जैसे कुछ शीर्ष-स्तरीय गुण हैं, साथ ही अंतिम नाम और आईग्रैस्टेड भी है, लेकिन इसमें नेस्टेड गुण भी हैं।

उदाहरण के लिए, माता-पिता की संपत्ति को JSON सरणी के रूप में वर्ग कोष्ठक द्वारा निरूपित किया जाता है। हमारे पास बच्चों के लिए एक और सरणी है, भले ही इस उदाहरण में सरणी में केवल एक बच्चा है।

Step 4 - दस्तावेज़ को बचाने के लिए 'सहेजें' बटन पर क्लिक करें और हमने अपना पहला दस्तावेज़ बनाया है।

जैसा कि आप देख सकते हैं कि हमारे JSON के लिए सुंदर प्रारूपण लागू किया गया था, जो प्रत्येक संपत्ति के प्रत्येक स्तर को तोड़ने के लिए व्हाट्सएप के साथ प्रत्येक संपत्ति के घोंसले के स्तर को व्यक्त करता है।

पोर्टल में एक डॉक्यूमेंट एक्सप्लोरर शामिल है, तो चलिए अब उस डॉक्यूमेंट को पुनः प्राप्त करने के लिए उपयोग करते हैं जिसे हमने अभी बनाया है।

Step 5- उस संग्रह में दस्तावेजों को देखने के लिए डेटाबेस के भीतर एक डेटाबेस और किसी भी संग्रह को चुनें। वर्तमान में हमारे पास केवल एक डेटाबेस है जिसका नाम मायफिल्डब है, जिसका एक संग्रह फैमिलीज है, दोनों को यहां ड्रॉपडाउन में रखा गया है।

डिफ़ॉल्ट रूप से, दस्तावेज़ एक्सप्लोरर संग्रह के भीतर दस्तावेजों की एक अनफ़िल्टर्ड सूची प्रदर्शित करता है, लेकिन आप आईडी द्वारा किसी विशिष्ट दस्तावेज़ के लिए या किसी आंशिक आईडी की वाइल्डकार्ड खोज पर आधारित कई दस्तावेज़ भी खोज सकते हैं।

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

Step 6 - डॉक्यूमेंट देखने के लिए आईडी पर क्लिक करें।

.NET SDK के साथ दस्तावेज़ बनाना

जैसा कि आप जानते हैं कि दस्तावेज़ केवल एक अन्य प्रकार के संसाधन हैं और आप पहले ही इस बात से परिचित हो चुके हैं कि एसडीके का उपयोग करके संसाधनों का इलाज कैसे किया जाए।

  • दस्तावेजों और अन्य संसाधनों के बीच एक बड़ा अंतर यह है कि बेशक, वे स्कीमा मुक्त हैं।

  • इस प्रकार बहुत सारे विकल्प हैं। स्वाभाविक रूप से, आप सिर्फ JSON ऑब्जेक्ट ग्राफ़ या यहां तक ​​कि JSON टेक्स्ट के कच्चे तार भी काम कर सकते हैं, लेकिन आप गतिशील वस्तुओं का भी उपयोग कर सकते हैं जो आपको संकलन समय पर एक वर्ग को परिभाषित किए बिना रनटाइम पर संपत्तियों को बांधने देता है।

  • आप वास्तविक C # ऑब्जेक्ट्स, या संस्थाओं के साथ भी काम कर सकते हैं, जैसा कि उन्हें कहा जाता है, जो आपके व्यवसाय के डोमेन वर्ग हो सकते हैं।

चलो .Net SDK का उपयोग करके दस्तावेज़ बनाना शुरू करते हैं। निम्नलिखित कदम हैं।

Step 1 - झटपट दस्तावेज़क्लिक करें, फिर हम myfirstdb डेटाबेस के लिए क्वेरी करेंगे और फिर MyCollection संग्रह के लिए क्वेरी करेंगे, जिसे हम इस निजी चर संग्रह में संग्रहीत करते हैं ताकि यह पूरे कक्षा में सुलभ हो।

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); 
   } 
}

Step 2 - CreateDocuments कार्य में कुछ दस्तावेज बनाएं।

private async static Task CreateDocuments(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** Create Documents ****"); 
   Console.WriteLine();
	
   dynamic document1Definition = new {
      name = "New Customer 1", address = new {
         addressType = "Main Office", 
         addressLine1 = "123 Main Street", 
         location = new {
            city = "Brooklyn", stateProvinceName = "New York" 
         }, postalCode = "11229", countryRegionName = "United States"
      }, 
   };
	
   Document document1 = await CreateDocument(client, document1Definition); 
   Console.WriteLine("Created document {0} from dynamic object", document1.Id); 
   Console.WriteLine(); 
}

इस गतिशील वस्तु से पहला दस्तावेज़ उत्पन्न होगा। यह JSON की तरह लग सकता है, लेकिन निश्चित रूप से यह नहीं है। यह C # कोड है और हम एक वास्तविक .NET ऑब्जेक्ट बना रहे हैं, लेकिन इसकी कोई वर्ग परिभाषा नहीं है। इसके बजाय, जिस तरह से ऑब्जेक्ट को इनिशियलाइज़ किया जाता है, उससे गुणों का अनुमान लगाया जाता है।

ध्यान दें कि हमने इस दस्तावेज़ के लिए कोई Id प्रॉपर्टी नहीं दी है।

अब CreateDocument पर एक नजर डालते हैं। यह उसी पैटर्न जैसा दिखता है जिसे हमने डेटाबेस और संग्रह बनाने के लिए देखा था।

private async static Task<Document> CreateDocument(DocumentClient client,
   object documentObject) {
	
   var result = await client.CreateDocumentAsync(collection.SelfLink, documentObject); 
   var document = result.Resource;
	
   Console.WriteLine("Created new document: {0}\r\n{1}", document.Id, document); 
   return result; 
}

Step 3- इस बार हम CreateDocumentAsync को उस संग्रह का SelfLink निर्दिष्ट करते हैं जिसे हम दस्तावेज़ में जोड़ना चाहते हैं। हमें एक संसाधन संपत्ति के साथ एक प्रतिक्रिया मिलती है जो इस मामले में, अपने सिस्टम-जनरेटेड गुणों के साथ नए दस्तावेज़ का प्रतिनिधित्व करती है।

दस्तावेज़ ऑब्जेक्ट एसडीके में एक परिभाषित वर्ग है जो संसाधन से विरासत में मिला है और इसलिए इसमें सभी सामान्य संसाधन गुण हैं, लेकिन इसमें डायनामिक गुण भी शामिल हैं जो स्कीमा-मुक्त दस्तावेज़ को स्वयं परिभाषित करते हैं।

private async static Task CreateDocuments(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** Create Documents ****"); 
   Console.WriteLine();  
	
   dynamic document1Definition = new {
      name = "New Customer 1", address = new { 
         addressType = "Main Office",
         addressLine1 = "123 Main Street", 
         location = new {
            city = "Brooklyn", stateProvinceName = "New York" 
         }, postalCode = "11229", countryRegionName = "United States" 
      }, 
   };
	
   Document document1 = await CreateDocument(client, document1Definition); 
   Console.WriteLine("Created document {0} from dynamic object", document1.Id); 
   Console.WriteLine();
}

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

**** Create Documents ****  
Created new document: 34e9873a-94c8-4720-9146-d63fb7840fad {
   "name": "New Customer 1", 
	
   "address": { 
      "addressType": "Main Office", 
      "addressLine1": "123 Main Street", 
      "location": { 
         "city": "Brooklyn", "stateProvinceName": "New York" 
      }, 
      "postalCode": "11229", "countryRegionName": "United States"
   }, 
	
   "id": "34e9873a-94c8-4720-9146-d63fb7840fad", 
   "_rid": "Ic8LAMEUVgACAAAAAAAAAA==", 
   "_ts": 1449812756, 
   "_self": "dbs/Ic8LAA==/colls/Ic8LAMEUVgA=/docs/Ic8LAMEUVgACAAAAAAAAAA==/", 
   "_etag": "\"00001000-0000-0000-0000-566a63140000\"", 
   "_attachments": "attachments/" 
} 
Created document 34e9873a-94c8-4720-9146-d63fb7840fad from dynamic object

जैसा कि आप देख सकते हैं, हमने एक Id की आपूर्ति नहीं की है, लेकिन 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

इस अध्याय में, हम सीखेंगे कि दस्तावेजों को कैसे अपडेट किया जाए। एज़्योर पोर्टल का उपयोग करके, आप दस्तावेज़ एक्सप्लोरर में दस्तावेज़ को खोलकर और इसे टेक्स्ट फ़ाइल की तरह संपादक में अपडेट करके आसानी से दस्तावेज़ को अपडेट कर सकते हैं।

'सेव' बटन पर क्लिक करें। अब जब आपको .Net SDK का उपयोग करके किसी डॉक्यूमेंट को बदलना होगा तो आप इसे बदल सकते हैं। आपको इसे हटाने और पुनः बनाने की आवश्यकता नहीं है, जो थकाऊ होने के अलावा, संसाधन आईडी को भी बदल देगा, जिसे आप तब नहीं करना चाहेंगे जब आप केवल एक दस्तावेज़ को संशोधित कर रहे हों। .Net SDK का उपयोग करके दस्तावेज़ को अद्यतन करने के लिए यहाँ निम्नलिखित चरण दिए गए हैं।

आइए निम्नलिखित प्रतिस्थापन कार्य पर एक नज़र डालें जहां हम उन दस्तावेज़ों के लिए क्वेरी करेंगे जहाँ isnew गुण सत्य है, लेकिन हमें कोई भी नहीं मिलेगा क्योंकि कोई भी नहीं है। तो, चलिए उन दस्तावेजों को संशोधित करते हैं जिन्हें हमने पहले जोड़ा था, जिनके नाम नए ग्राहक के साथ शुरू होते हैं।

Step 1 - इन दस्तावेजों में isNew संपत्ति जोड़ें और इसके मूल्य को सही पर सेट करें।

private async static Task ReplaceDocuments(DocumentClient client) {

   Console.WriteLine(); 
   Console.WriteLine(">>> Replace Documents <<<"); 
   Console.WriteLine();  
   Console.WriteLine("Quering for documents with 'isNew' flag");
	
   var sql = "SELECT * FROM c WHERE c.isNew = true"; 
   var documents = client.CreateDocumentQuery(collection.SelfLink, sql).ToList();
	
   Console.WriteLine("Documents with 'isNew' flag: {0} ", documents.Count); 
   Console.WriteLine();  
   Console.WriteLine("Quering for documents to be updated"); 
	
   sql = "SELECT * FROM c WHERE STARTSWITH(c.name, 'New Customer') = true"; 
   documents = client.CreateDocumentQuery(collection.SelfLink, sql).ToList(); 
   Console.WriteLine("Found {0} documents to be updated", documents.Count); 
	
   foreach (var document in documents) {
      document.isNew = true; 
      var result = await client.ReplaceDocumentAsync(document._self, document); 
      var updatedDocument = result.Resource; 
      Console.WriteLine("Updated document 'isNew' flag: {0}", updatedDocument.isNew); 
   }
	
   Console.WriteLine();  
   Console.WriteLine("Quering for documents with 'isNew' flag");
	
   sql = "SELECT * FROM c WHERE c.isNew = true"; 
   documents = client.CreateDocumentQuery(collection.SelfLink, sql).ToList(); 
   Console.WriteLine("Documents with 'isNew' flag: {0}: ", documents.Count); 
   Console.WriteLine(); 
}

Step 2 - उसी STARTSWITH क्वेरी का उपयोग करके अपडेट किए जाने वाले दस्तावेज़ प्राप्त करें और यह हमें दस्तावेज़ प्रदान करता है, जिसे हम डायनामिक ऑब्जेक्ट के रूप में यहां वापस ला रहे हैं।

Step 3 - isnew संपत्ति संलग्न करें और इसे प्रत्येक दस्तावेज़ के लिए सही पर सेट करें।

Step 4 - अपडेट किए गए डॉक्यूमेंट के साथ डॉक्यूमेंटडिमेंमेंटएस्प्यून्स, डॉक्यूमेंट के सेल्फलिंक में पास करना

अब सिर्फ यह साबित करने के लिए कि यह काम किया है, उन दस्तावेजों के लिए क्वेरी करें जहां नया सही नहीं है। आइए 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);  
      //QueryDocumentsWithSql(client); 
      //await QueryDocumentsWithPaging(client); 
      //QueryDocumentsWithLinq(client); 
      await ReplaceDocuments(client); 
   }
	
}

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

**** Replace Documents ****  
Quering for documents with 'isNew' flag 
Documents with 'isNew' flag: 0 
Quering for documents to be updated 
Found 2 documents to be updated 
Updated document ‘isNew’ flag: True 
Updated document ‘isNew’ flag: True 
Quering for documents with 'isNew' flag 
Documents with 'isNew' flag: 2

इस अध्याय में, हम सीखेंगे कि अपने डॉक्यूमेंटबैंक खाते से किसी दस्तावेज़ को कैसे हटाएं। एज़्योर पोर्टल का उपयोग करके, आप दस्तावेज़ एक्सप्लोरर में दस्तावेज़ खोलकर किसी भी दस्तावेज़ को आसानी से हटा सकते हैं और 'हटाएं' विकल्प पर क्लिक कर सकते हैं।

यह पुष्टिकरण संदेश प्रदर्शित करेगा। अब Yes बटन दबाएं और आप देखेंगे कि दस्तावेज़ आपके DocumentDB खाते में उपलब्ध नहीं है।

अब जब आप .Net SDK का उपयोग करके किसी डॉक्यूमेंट को हटाना चाहते हैं।

Step 1- यह वही पैटर्न है जैसा कि हमने पहले देखा है जहां हम प्रत्येक नए दस्तावेज़ के सेल्फलिंक प्राप्त करने के लिए पहले क्वेरी करेंगे। हम यहां SELECT * का उपयोग नहीं करते हैं, जो दस्तावेजों को उनकी संपूर्णता में लौटा देगा, जिनकी हमें आवश्यकता नहीं है।

Step 2 - इसके बजाय हम केवल एक सूची में सेल्फलिंक का चयन कर रहे हैं और फिर हम संग्रह से दस्तावेजों को हटाने के लिए, एक बार में प्रत्येक सेल्फलिंक के लिए DeleteDocumentAsync कहते हैं।

private async static Task DeleteDocuments(DocumentClient client) {
   Console.WriteLine();
   Console.WriteLine(">>> Delete Documents <<<");
   Console.WriteLine();
   Console.WriteLine("Quering for documents to be deleted");
	
   var sql =
      "SELECT VALUE c._self FROM c WHERE STARTSWITH(c.name, 'New Customer') = true";
		
   var documentLinks =
      client.CreateDocumentQuery<string>(collection.SelfLink, sql).ToList();
		
   Console.WriteLine("Found {0} documents to be deleted", documentLinks.Count);

   foreach (var documentLink in documentLinks) {
      await client.DeleteDocumentAsync(documentLink);
   }
	
   Console.WriteLine("Deleted {0} new customer documents", documentLinks.Count);
   Console.WriteLine();
}

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

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 DeleteDocuments(client); 
   } 
}

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

***** Delete Documents *****  
Quering for documents to be deleted 
Found 2 documents to be deleted 
Deleted 2 new customer documents

हालाँकि, स्कीमा-रहित डेटाबेस, जैसे डॉक्यूमेंटीडीबी, आपके डेटा मॉडल में परिवर्तन को गले लगाने के लिए सुपर आसान बनाते हैं, आपको अभी भी अपने डेटा के बारे में सोचने में कुछ समय बिताना चाहिए।

  • आपके पास बहुत सारे विकल्प हैं। स्वाभाविक रूप से, आप सिर्फ JSON ऑब्जेक्ट ग्राफ़ या यहां तक ​​कि JSON टेक्स्ट के कच्चे तार भी काम कर सकते हैं, लेकिन आप गतिशील वस्तुओं का भी उपयोग कर सकते हैं जो आपको संकलन समय पर एक वर्ग को परिभाषित किए बिना रनटाइम पर संपत्तियों को बांधने देता है।

  • आप वास्तविक C # ऑब्जेक्ट्स, या संस्थाओं के साथ भी काम कर सकते हैं, जैसा कि उन्हें कहा जाता है, जो आपके व्यवसाय के डोमेन वर्ग हो सकते हैं।

रिश्तों

आइए दस्तावेज़ के पदानुक्रम संरचना पर एक नज़र डालें। इसमें आवश्यक आईडी की तरह कुछ शीर्ष-स्तरीय गुण हैं, साथ ही साथ अंतिम नाम और आइज़िस्टरिस्टर भी हैं, लेकिन इसमें शून्य गुण भी हैं।

{ 
   "id": "AndersenFamily", 
   "lastName": "Andersen", 
	
   "parents": [ 
      { "firstName": "Thomas", "relationship": "father" }, 
      { "firstName": "Mary Kay", "relationship": "mother" } 
   ],
	
   "children": [ 
      { 
         "firstName": "Henriette Thaulow", 
         "gender": "female", 
         "grade": 5, 
         "pets": [ { "givenName": "Fluffy", "type": "Rabbit" } ] 
      } 
   ], 
	
   "location": { "state": "WA", "county": "King", "city": "Seattle"}, 
   "isRegistered": true 
}
  • उदाहरण के लिए, माता-पिता की संपत्ति को JSON सरणी के रूप में वर्ग कोष्ठक द्वारा निरूपित किया जाता है।

  • हमारे पास बच्चों के लिए एक और सरणी है, भले ही इस उदाहरण में सरणी में केवल एक बच्चा है। तो यह है कि आप दस्तावेज़ के भीतर एक-से-कई संबंधों के बराबर मॉडल कैसे बनाते हैं।

  • आप बस सरणियों का उपयोग करते हैं जहां सरणी में प्रत्येक तत्व एक साधारण मूल्य या कोई अन्य जटिल वस्तु, यहां तक ​​कि एक और सरणी भी हो सकती है।

  • इसलिए एक परिवार में कई माता-पिता और कई बच्चे हो सकते हैं और यदि आप बाल वस्तुओं को देखते हैं, तो उनके पास एक पालतू जानवर की संपत्ति है जो कि बच्चों और पालतू जानवरों के बीच कई संबंधों के लिए एक नेस्टेड सरणी है।

  • स्थान संपत्ति के लिए, हम तीन संबंधित गुणों, राज्य, काउंटी और शहर को एक वस्तु में मिला रहे हैं।

  • ऑब्जेक्ट को एंबेड करने के बजाय ऑब्जेक्ट को एंबेड करना एक रिलेशनल डेटाबेस में अलग-अलग टेबलों में दो पंक्तियों के बीच एक-से-एक संबंध रखने के समान है।

डेटा एम्बेड करना

जब आप किसी डॉक्यूमेंट स्टोर में दस्तावेज़ डेटा को मॉडलिंग करना शुरू करते हैं, जैसे कि डॉक्यूडीडीबी, तो अपनी संस्थाओं को JSON में दर्शाए गए स्व-निहित दस्तावेज़ों के रूप में मानने की कोशिश करें। रिलेशनल डेटाबेस के साथ काम करते समय, हम हमेशा डेटा को सामान्य करते हैं।

  • आपके डेटा को सामान्य करने में आम तौर पर एक इकाई लेना शामिल होता है, जैसे कि ग्राहक, और संपर्क विवरण और पते जैसे डेटा के विचारशील टुकड़ों में इसे तोड़ना।

  • एक ग्राहक को पढ़ने के लिए, उनके सभी संपर्क विवरण और पते के साथ, आपको अपने डेटा को प्रभावी ढंग से चलाने के लिए JOINS का उपयोग करना होगा।

अब हम इस पर एक नज़र डालते हैं कि हम एक ही डेटा को दस्तावेज़ डेटाबेस में स्व-निहित इकाई के रूप में कैसे मॉडल करेंगे।

{
   "id": "1", 
   "firstName": "Mark", 
   "lastName": "Upston", 
	
   "addresses": [ 
      {             
         "line1": "232 Main Street", 
         "line2": "Unit 1", 
         "city": "Brooklyn", 
         "state": "NY", 
         "zip": 11229
      }
   ],
	
   "contactDetails": [ 
      {"email": "[email protected]"}, 
      {"phone": "+1 356 545-86455", "extension": 5555} 
   ]
}

जैसा कि आप देख सकते हैं कि हमने ग्राहक के रिकॉर्ड को असामान्य कर दिया है, जहाँ ग्राहक की सभी जानकारी को एक JSON दस्तावेज़ में एम्बेड किया गया है।

NoSQL में हमारे पास एक मुफ्त स्कीमा है, इसलिए आप अलग-अलग प्रारूप में संपर्क विवरण और पते भी जोड़ सकते हैं। NoSQL में, आप एक एकल रीड ऑपरेशन में डेटाबेस से एक ग्राहक रिकॉर्ड प्राप्त कर सकते हैं। इसी तरह, रिकॉर्ड को अपडेट करना भी एक एकल लेखन ऑपरेशन है।

.Net SDK का उपयोग करके दस्तावेज़ बनाने के चरण निम्नलिखित हैं।

Step 1- झटपट दस्तावेज़क्लिक करें। तब हम myfirstdb डेटाबेस के लिए क्वेरी करेंगे और MyCollection संग्रह के लिए भी क्वेरी करेंगे, जिसे हम इस निजी चर संग्रह में संग्रहीत करते हैं ताकि यह पूरे कक्षा में सुलभ हो।

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); 
   }

}

Step 2 - CreateDocuments कार्य में कुछ दस्तावेज बनाएं।

private async static Task CreateDocuments(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** Create Documents ****"); 
   Console.WriteLine();
	
   dynamic document1Definition = new {
      name = "New Customer 1", address = new { 
         addressType = "Main Office", 
         addressLine1 = "123 Main Street", 
         location = new { 
            city = "Brooklyn", stateProvinceName = "New York"
         }, 
         postalCode = "11229", countryRegionName = "United States" 
      }, 
   };
	
   Document document1 = await CreateDocument(client, document1Definition); 
   Console.WriteLine("Created document {0} from dynamic object", document1.Id); 
   Console.WriteLine(); 
}

इस गतिशील वस्तु से पहला दस्तावेज़ उत्पन्न होगा। यह JSON की तरह लग सकता है, लेकिन निश्चित रूप से यह नहीं है। यह C # कोड है और हम एक वास्तविक .NET ऑब्जेक्ट बना रहे हैं, लेकिन इसकी कोई वर्ग परिभाषा नहीं है। इसके बजाय गुणों को ऑब्जेक्ट इनिशियलाइज़ किए जाने के तरीके से अनुमान लगाया जाता है। आप यह भी देख सकते हैं कि हमने इस दस्तावेज़ के लिए कोई Id प्रॉपर्टी नहीं दी है।

Step 3 - अब CreateDocument पर एक नज़र डालते हैं और यह उसी पैटर्न की तरह दिखता है जो हमने डेटाबेस और संग्रह बनाने के लिए देखा था।

private async static Task<Document> CreateDocument(DocumentClient client,
   object documentObject) {
   var result = await client.CreateDocumentAsync(collection.SelfLink, documentObject); 
	
   var document = result.Resource; 
   Console.WriteLine("Created new document: {0}\r\n{1}", document.Id, document); 
	
   return result; 
}

Step 4- इस बार हम CreateDocumentAsync को उस संग्रह का SelfLink निर्दिष्ट करते हैं जिसे हम दस्तावेज़ में जोड़ना चाहते हैं। हमें एक संसाधन संपत्ति के साथ एक प्रतिक्रिया मिलती है जो इस मामले में, अपने सिस्टम-जनरेटेड गुणों के साथ नए दस्तावेज़ का प्रतिनिधित्व करती है।

निम्नलिखित CreateDocuments कार्य में, हमने तीन दस्तावेज़ बनाए हैं।

  • पहले दस्तावेज़ में, दस्तावेज़ ऑब्जेक्ट एसडीके में एक परिभाषित वर्ग है जो संसाधन से विरासत में मिला है और इसलिए इसमें सभी सामान्य संसाधन गुण हैं, लेकिन इसमें डायनामिक गुण भी शामिल हैं जो स्कीमा-मुक्त दस्तावेज़ को परिभाषित करते हैं।

private async static Task CreateDocuments(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** Create Documents ****"); 
   Console.WriteLine();
	
   dynamic document1Definition = new {
      name = "New Customer 1", address = new {
         addressType = "Main Office", 
         addressLine1 = "123 Main Street", 
         location = new {
            city = "Brooklyn", stateProvinceName = "New York" 
         }, 
         postalCode = "11229", 
         countryRegionName = "United States" 
      }, 
   };
	
   Document document1 = await CreateDocument(client, document1Definition); 
   Console.WriteLine("Created document {0} from dynamic object", document1.Id); 
   Console.WriteLine();
	
   var document2Definition = @" {
      ""name"": ""New Customer 2"", 
		
      ""address"": { 
         ""addressType"": ""Main Office"", 
         ""addressLine1"": ""123 Main Street"", 
         ""location"": { 
            ""city"": ""Brooklyn"", ""stateProvinceName"": ""New York"" 
         }, 
         ""postalCode"": ""11229"", 
         ""countryRegionName"": ""United States"" 
      } 
   }"; 
	
   Document document2 = await CreateDocument(client, document2Definition); 
   Console.WriteLine("Created document {0} from JSON string", document2.Id);
   Console.WriteLine();
	
   var document3Definition = new Customer {
      Name = "New Customer 3", 
		
      Address = new Address {
         AddressType = "Main Office", 
         AddressLine1 = "123 Main Street", 
         Location = new Location {
            City = "Brooklyn", StateProvinceName = "New York" 
         }, 
         PostalCode = "11229", 
         CountryRegionName = "United States" 
      }, 
   };
	
   Document document3 = await CreateDocument(client, document3Definition); 
   Console.WriteLine("Created document {0} from typed object", document3.Id); 
   Console.WriteLine(); 
}
  • यह दूसरा दस्तावेज़ सिर्फ कच्चे JSON स्ट्रिंग के साथ काम करता है। अब हम CreateDocument के लिए एक अधिभार में कदम रखते हैं जो किसी ऑब्जेक्ट में स्ट्रिंग को डी-सीरियल करने के लिए JavaScriptSerializer का उपयोग करता है, जो तब उसी CreateDocument विधि पर गुजरता है जिसे हमने पहले दस्तावेज़ बनाने के लिए उपयोग किया था।

  • तीसरे दस्तावेज़ में, हमने C # ऑब्जेक्ट ग्राहक का उपयोग किया है जो हमारे आवेदन में परिभाषित है।

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

using Newtonsoft.Json; 

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks;

namespace DocumentDBDemo {
 
   public class Customer { 
      [JsonProperty(PropertyName = "id")] 
      public string Id { get; set; }
      // Must be nullable, unless generating unique values for new customers on client  
      [JsonProperty(PropertyName = "name")] 
      public string Name { get; set; }  
      [JsonProperty(PropertyName = "address")] 
      public Address Address { get; set; } 
   }
	
   public class Address {
      [JsonProperty(PropertyName = "addressType")] 
      public string AddressType { get; set; }  
		
      [JsonProperty(PropertyName = "addressLine1")] 
      public string AddressLine1 { get; set; }  
		
      [JsonProperty(PropertyName = "location")] 
      public Location Location { get; set; }  
		
      [JsonProperty(PropertyName = "postalCode")] 
      public string PostalCode { get; set; }  
		
      [JsonProperty(PropertyName = "countryRegionName")] 
      public string CountryRegionName { get; set; } 
   }
	
   public class Location { 
      [JsonProperty(PropertyName = "city")] 
      public string City { get; set; }  
		
      [JsonProperty(PropertyName = "stateProvinceName")]
      public string StateProvinceName { get; set; } 
   } 
}

हमारे पास JSON संपत्ति विशेषताएँ भी हैं क्योंकि हम बाड़ के दोनों किनारों पर उचित सम्मेलनों को बनाए रखना चाहते हैं।

इसलिए मैं सिर्फ अपने नेस्टेड चाइल्ड ऑब्जेक्ट्स के साथ अपनी नई ग्राहक वस्तु बनाता हूं और एक बार फिर CreateDocument में कॉल करता हूं। हालाँकि हमारी ग्राहक वस्तु में एक Id प्रॉपर्टी है, जिसके लिए हमने कोई वैल्यू सप्लाई नहीं की थी और इसलिए DocumentDB ने GUID के आधार पर एक को जेनरेट किया, जैसे पिछले दो डॉक्यूमेंट्स के लिए किया था।

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

**** Create Documents ****  
Created new document: 575882f0-236c-4c3d-81b9-d27780206b2c 
{ 
  "name": "New Customer 1", 
  "address": { 
    "addressType": "Main Office", 
    "addressLine1": "123 Main Street", 
    "location": { 
      "city": "Brooklyn", 
      "stateProvinceName": "New York" 
    }, 
    "postalCode": "11229", 
    "countryRegionName": "United States" 
  }, 
  "id": "575882f0-236c-4c3d-81b9-d27780206b2c", 
  "_rid": "kV5oANVXnwDGPgAAAAAAAA==", 
  "_ts": 1450037545, 
  "_self": "dbs/kV5oAA==/colls/kV5oANVXnwA=/docs/kV5oANVXnwDGPgAAAAAAAA==/", 
  "_etag": "\"00006fce-0000-0000-0000-566dd1290000\"", 
  "_attachments": "attachments/" 
} 
Created document 575882f0-236c-4c3d-81b9-d27780206b2c from dynamic object  
Created new document: 8d7ad239-2148-4fab-901b-17a85d331056 
{ 
  "name": "New Customer 2", 
  "address": {
    "addressType": "Main Office", 
    "addressLine1": "123 Main Street", 
    "location": { 
      "city": "Brooklyn", 
      "stateProvinceName": "New York" 
    }, 
    "postalCode": "11229", 
    "countryRegionName": "United States" 
  }, 
  "id": "8d7ad239-2148-4fab-901b-17a85d331056", 
  "_rid": "kV5oANVXnwDHPgAAAAAAAA==", 
  "_ts": 1450037545, 
  "_self": "dbs/kV5oAA==/colls/kV5oANVXnwA=/docs/kV5oANVXnwDHPgAAAAAAAA==/", 
  "_etag": "\"000070ce-0000-0000-0000-566dd1290000\"", 
  "_attachments": "attachments/" 
} 
Created document 8d7ad239-2148-4fab-901b-17a85d331056 from JSON string  
Created new document: 49f399a8-80c9-4844-ac28-cd1dee689968 
{ 
  "id": "49f399a8-80c9-4844-ac28-cd1dee689968", 
  "name": "New Customer 3", 
  "address": { 
    "addressType": "Main Office", 
    "addressLine1": "123 Main Street", 
    "location": { 
      "city": "Brooklyn", 
      "stateProvinceName": "New York" 
    }, 
    "postalCode": "11229", 
    "countryRegionName": "United States" 
  }, 
  "_rid": "kV5oANVXnwDIPgAAAAAAAA==", 
  "_ts": 1450037546, 
  "_self": "dbs/kV5oAA==/colls/kV5oANVXnwA=/docs/kV5oANVXnwDIPgAAAAAAAA==/", 
  "_etag": "\"000071ce-0000-0000-0000-566dd12a0000\"", 
  "_attachments": "attachments/" 
}
Created document 49f399a8-80c9-4844-ac28-cd1dee689968 from typed object

JSON या जावास्क्रिप्ट ऑब्जेक्ट नोटेशन एक हल्का टेक्स्ट-आधारित खुला मानक है जो मानव-पठनीय डेटा इंटरचेंज के लिए डिज़ाइन किया गया है और मशीनों को पार्स और जेनरेट करने के लिए भी आसान है। JSON दस्तावेज़डीबी के केंद्र में है। हम JSON को तार पर प्रसारित करते हैं, हम JSON को JSON के रूप में संग्रहीत करते हैं, और हम JSON ट्री को पूर्ण JSON दस्तावेज़ पर क्वेरीज़ की अनुमति देते हुए अनुक्रमित करते हैं।

JSON प्रारूप निम्नलिखित डेटा प्रकारों का समर्थन करता है -

क्र.सं. टाइप और विवरण
1

Number

जावास्क्रिप्ट में डबल-सटीक फ़्लोटिंग-पॉइंट प्रारूप

2

String

बैकस्लैश भागने के साथ डबल-यूनिकोड

3

Boolean

सही या गलत

4

Array

मूल्यों का एक क्रमबद्ध क्रम

5

Value

यह एक तार, एक संख्या, सही या गलत, अशक्त आदि हो सकता है।

6

Object

कुंजी का एक अनियंत्रित संग्रह: मूल्य जोड़े

7

Whitespace

यह किसी भी जोड़ी के टोकन के बीच इस्तेमाल किया जा सकता है

8

Null

खाली

आइए एक सरल उदाहरण DateTime प्रकार पर एक नज़र डालें। ग्राहक वर्ग में जन्म तिथि जोड़ें।

public class Customer {
   [JsonProperty(PropertyName = "id")] 
   public string Id { get; set; }
	
   // Must be nullable, unless generating unique values for new customers on client  
   [JsonProperty(PropertyName = "name")] 
   public string Name { get; set; }  
	
   [JsonProperty(PropertyName = "address")] 
   public Address Address { get; set; }  
	
   [JsonProperty(PropertyName = "birthDate")] 
   public DateTime BirthDate { get; set; } 
}

हम निम्न समय में दिखाए गए अनुसार DateTime का उपयोग करके स्टोर, पुनर्प्राप्त और क्वेरी कर सकते हैं।

private async static Task CreateDocuments(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** Create Documents ****"); 
   Console.WriteLine();
	
   var document3Definition = new Customer { 
      Id = "1001", 
      Name = "Luke Andrew", 
		
      Address = new Address { 
         AddressType = "Main Office", 
         AddressLine1 = "123 Main Street", 
         Location = new Location {
            City = "Brooklyn",
            StateProvinceName = "New York" 
         }, 
         PostalCode = "11229",
         CountryRegionName = "United States" 
      },
		
      BirthDate = DateTime.Parse(DateTime.Today.ToString()), 
   };
	
   Document document3 = await CreateDocument(client, document3Definition); 
   Console.WriteLine("Created document {0} from typed object", document3.Id); 
   Console.WriteLine(); 
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, और दस्तावेज़ बनाया जाता है, तो आप देखेंगे कि जन्म तिथि अब जोड़ दी गई है।

**** Create Documents ****  
Created new document: 1001 
{ 
   "id": "1001", 
   "name": "Luke Andrew", 
   "address": { 
      "addressType": "Main Office", 
      "addressLine1": "123 Main Street", 
      "location": { 
         "city": "Brooklyn", 
         "stateProvinceName": "New York" 
      }, 
      "postalCode": "11229", 
      "countryRegionName": "United States" 
   }, 
   "birthDate": "2015-12-14T00:00:00", 
   "_rid": "Ic8LAMEUVgAKAAAAAAAAAA==", 
   "_ts": 1450113676, 
   "_self": "dbs/Ic8LAA==/colls/Ic8LAMEUVgA=/docs/Ic8LAMEUVgAKAAAAAAAAAA==/", 
   "_etag": "\"00002d00-0000-0000-0000-566efa8c0000\"", 
   "_attachments": "attachments/" 
} 
Created document 1001 from typed object

Microsoft ने हाल ही में कई सुधारों को जोड़ा है कि आप Azure DocumentDB को कैसे क्वेरी कर सकते हैं, जैसे कि TOP टू SQL व्याकरण, जिससे प्रश्न तेज़ी से चलते हैं और कम संसाधनों का उपभोग करते हैं, क्वेरी ऑपरेटरों के लिए सीमाएँ बढ़ जाती हैं, और अतिरिक्त LINQ ऑपरेटरों के लिए समर्थन जोड़ा जाता है। .NET SDK

आइए एक सरल उदाहरण देखें, जिसमें हम केवल पहले दो रिकॉर्ड प्राप्त करेंगे। यदि आपके पास कई रिकॉर्ड हैं और आप उनमें से कुछ को ही पुनः प्राप्त करना चाहते हैं, तो आप शीर्ष कीवर्ड का उपयोग कर सकते हैं। इस उदाहरण में, हमारे पास भूकंपों के बहुत सारे रिकॉर्ड हैं।

अब हम पहले दो रिकॉर्ड दिखाना चाहते हैं

Step 1 - क्वेरी एक्सप्लोरर पर जाएं और इस क्वेरी को चलाएं।

SELECT * FROM c 
WHERE c.magnitude > 2.5

आप देखेंगे कि इसने चार रिकॉर्ड प्राप्त किए हैं क्योंकि हमने अभी तक TOP कीवर्ड निर्दिष्ट नहीं किए हैं।

Step 2- अब उसी क्वेरी के साथ TOP कीवर्ड का उपयोग करें। यहां हमने TOP कीवर्ड निर्दिष्ट किया है और '2' का अर्थ है कि हम केवल दो रिकॉर्ड चाहते हैं।

SELECT TOP 2 * FROM c 
WHERE c.magnitude > 2.5

Step 3 - अब इस क्वेरी को चलाएं और आप देखेंगे कि केवल दो रिकॉर्ड्स को पुनः प्राप्त किया गया है।

इसी तरह, आप .net SDK का उपयोग करके कोड में TOP कीवर्ड का उपयोग कर सकते हैं। निम्नलिखित कार्यान्वयन है।

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 TOP 3 * 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(" PublicId: {0}; Magnitude: {1};", document.publicid,
            document.magnitude); 
      } 
   } 
	
   Console.WriteLine(); 
}

निम्नलिखित CreateDocumentClient कार्य है, जिसमें DocumentClient और भूकंप डेटाबेस को त्वरित किया जाता है।

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 =
         'earthquake'").AsEnumerable().First(); 
			
      collection = client.CreateDocumentCollectionQuery(database.CollectionsLink,
         "SELECT * FROM c WHERE c.id = 'earthquakedata'").AsEnumerable().First(); 
			
      await QueryDocumentsWithPaging(client); 
   } 
}

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

**** Query Documents (paged results) **** 
 
Quering for all documents 
PublicId: 2015p947400; Magnitude: 2.515176918; 
PublicId: 2015p947373; Magnitude: 1.506774108; 
PublicId: 2015p947329; Magnitude: 1.593394461;

Microsoft Azure DocumentDB JSON दस्तावेज़ों पर SQL का उपयोग करते हुए क्वेरीज़ दस्तावेजों का समर्थन करता है। आप अपनी क्वेरी में ORDER BY क्लॉज़ का उपयोग करके संख्या और स्ट्रिंग्स पर संग्रह में दस्तावेज़ों को सॉर्ट कर सकते हैं। क्लॉज में ऑर्डर को निर्दिष्ट करने के लिए एक वैकल्पिक ASC / DESC तर्क शामिल हो सकता है जिसमें परिणाम पुनर्प्राप्त किए जाने चाहिए।

आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें हमारे पास JSON दस्तावेज़ है।

{ 
   "id": "Food Menu",
   "description": "Grapes, red or green (European type, such as Thompson seedless), raw",
	
   "tags": [
      {
         "name": "grapes"
      },
		
      {
         "name": "red or green (european type"
      },
		
      {
         "name": "such as thompson seedless)"
      },
		
      {
         "name": "raw"
      }
   ],
	
   "foodGroup": "Fruits and Fruit Juices",
	
   "servings": [
      {
         "amount": 1,
         "description": "cup",
         "weightInGrams": 151
      },
		
      {
         "amount": 10,
         "description": "grapes",
         "weightInGrams": 49
      },
		
      {
         "amount": 1,
         "description": "NLEA serving",
         "weightInGrams": 126
      }
   ]
	
}

एक अवरोही क्रम में परिणाम को सॉर्ट करने के लिए SQL क्वेरी निम्न है।

SELECT f.description, f.foodGroup,  
   f.servings[2].description AS servingDescription,  
   f.servings[2].weightInGrams AS servingWeight  
	
FROM f  
ORDER BY f.servings[2].weightInGrams DESC

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

[
   {
      "description": "Grapes, red or green (European type, such as Thompson
         seedless), raw",
      "foodGroup": "Fruits and Fruit Juices",
      "servingDescription": "NLEA serving",
      "servingWeight": 126
   }
]

डिफ़ॉल्ट रूप से, DocumentDB डेटाबेस में दस्तावेज़ को जोड़ते ही दस्तावेज़ के प्रत्येक गुण को स्वचालित रूप से अनुक्रमित करता है। हालांकि, आप अपनी खुद की अनुक्रमण नीति को नियंत्रित और ठीक कर सकते हैं जो स्टोरेज और प्रसंस्करण को कम कर देता है जब विशिष्ट दस्तावेज और / या गुण होते हैं जिन्हें कभी अनुक्रमित करने की आवश्यकता नहीं होती है।

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

DocumentDB निम्नलिखित प्रकार के अनुक्रमण का समर्थन करता है -

  • Hash
  • Range

हैश

हैश इंडेक्स समानता के लिए कुशल क्वेरी करने में सक्षम बनाता है, अर्थात, दस्तावेजों की खोज करते समय, जहां एक दी गई संपत्ति एक सटीक मान के बराबर होती है, बजाय एक मान की सीमा पर, इससे कम या अधिक से अधिक।

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

आप अपने दस्तावेज़ों को ORDER BY खंड के साथ एक संपत्ति पर सॉर्ट करने में सक्षम नहीं होंगे, जिसमें सिर्फ हैश इंडेक्स है।

रेंज

संपत्ति के लिए परिभाषित रेंज इंडेक्स, डॉक्यूमेंटीडीबी कई प्रकार के मूल्यों के खिलाफ दस्तावेजों के लिए कुशलतापूर्वक क्वेरी करने की अनुमति देता है। यह आपको ORDER BY का उपयोग करके उस संपत्ति पर क्वेरी परिणामों को क्रमबद्ध करने की अनुमति भी देता है।

DocumentDB आपको किसी भी या सभी गुणों पर हैश और रेंज इंडेक्स दोनों को परिभाषित करने की अनुमति देता है, जो कुशल समानता और श्रेणी के प्रश्नों को सक्षम करता है, साथ ही साथ ORDER BY।

अनुक्रमण नीति

प्रत्येक संग्रह में एक अनुक्रमण नीति होती है जो यह निर्धारित करती है कि प्रत्येक दस्तावेज़ की प्रत्येक संपत्ति में संख्याओं और तारों के लिए किस प्रकार के सूचकांक का उपयोग किया जाता है।

  • आप यह भी नियंत्रित कर सकते हैं कि संग्रह में जोड़े जाने के साथ दस्तावेज़ स्वचालित रूप से अनुक्रमित हो जाते हैं या नहीं।

  • स्वचालित अनुक्रमण डिफ़ॉल्ट रूप से सक्षम है, लेकिन आप दस्तावेज़ को जोड़ते समय उस व्यवहार को ओवरराइड कर सकते हैं, डॉक्यूमेंटीडीबी को उस विशेष दस्तावेज़ को अनुक्रमणित नहीं करने के लिए कह सकते हैं।

  • आप स्वचालित अनुक्रमण को अक्षम कर सकते हैं ताकि डिफ़ॉल्ट रूप से, संग्रह में जोड़े जाने पर दस्तावेज़ अनुक्रमित न हों। इसी तरह, आप इसे दस्तावेज़ स्तर पर ओवरराइड कर सकते हैं और संग्रह में जोड़ते समय किसी विशेष दस्तावेज़ को अनुक्रमित करने के लिए DocumentDB को निर्देश दे सकते हैं। इसे मैनुअल इंडेक्सिंग के रूप में जाना जाता है।

शामिल करें / बहिष्कृत अनुक्रमण करें

एक इंडेक्सिंग पॉलिसी यह भी परिभाषित कर सकती है कि किस पथ या पथ को इंडेक्स से शामिल किया जाना चाहिए या बाहर रखा जाना चाहिए। यह उपयोगी है यदि आप जानते हैं कि एक दस्तावेज़ के कुछ हिस्से हैं जिनके बारे में आप कभी भी पूछताछ नहीं करते हैं और कुछ हिस्से जो आप करते हैं।

इन मामलों में, आप संग्रह में जोड़े गए प्रत्येक दस्तावेज़ के उन विशेष भागों को अनुक्रमित करने के लिए DocumentDB को बताकर इंडेक्सिंग ओवरहेड को कम कर सकते हैं।

स्वचालित अनुक्रमण

आइए स्वचालित अनुक्रमण के एक सरल उदाहरण पर एक नज़र डालें।

Step 1 - पहले हम ऑटिंडेक्सिंग नामक एक संग्रह बनाते हैं और स्पष्ट रूप से किसी नीति की आपूर्ति किए बिना, यह संग्रह डिफ़ॉल्ट अनुक्रमण नीति का उपयोग करता है, जिसका अर्थ है कि इस संग्रह पर स्वचालित अनुक्रमण सक्षम है।

यहां हम डेटाबेस सेल्फ-लिंक के लिए आईडी-आधारित रूटिंग का उपयोग कर रहे हैं, इसलिए हमें संग्रह बनाने से पहले इसके संसाधन आईडी या क्वेरी को जानने की आवश्यकता नहीं है। हम सिर्फ डेटाबेस आईडी का उपयोग कर सकते हैं, जो कि mydb है।

Step 2 - अब दो दस्तावेज बनाते हैं, दोनों उपस्टोन के अंतिम नाम के साथ।

private async static Task AutomaticIndexing(DocumentClient client) {
   Console.WriteLine();
   Console.WriteLine("**** Override Automatic Indexing ****");

   // Create collection with automatic indexing

   var collectionDefinition = new DocumentCollection {
      Id = "autoindexing"
   };
	
   var collection = await client.CreateDocumentCollectionAsync("dbs/mydb",
      collectionDefinition);

   // Add a document (indexed)
   dynamic indexedDocumentDefinition = new {
      id = "MARK",
      firstName = "Mark",
      lastName = "Upston",
      addressLine = "123 Main Street",
      city = "Brooklyn",
      state = "New York",
      zip = "11229",
   };
	
   Document indexedDocument = await client
      .CreateDocumentAsync("dbs/mydb/colls/autoindexing", indexedDocumentDefinition);
		
   // Add another document (request no indexing)
   dynamic unindexedDocumentDefinition = new {
      id = "JANE",
      firstName = "Jane",
      lastName = "Upston",
      addressLine = "123 Main Street",
      city = "Brooklyn",
      state = "New York",
      zip = "11229",
   };
	
   Document unindexedDocument = await client
      .CreateDocumentAsync("dbs/mydb/colls/autoindexing", unindexedDocumentDefinition,
      new RequestOptions { IndexingDirective = IndexingDirective.Exclude });

   //Unindexed document won't get returned when querying on non-ID (or selflink) property

   var doeDocs = client.CreateDocumentQuery("dbs/mydb/colls/autoindexing", "SELECT *
      FROM c WHERE c.lastName = 'Doe'").ToList();
		
   Console.WriteLine("Documents WHERE lastName = 'Doe': {0}", doeDocs.Count);

   // Unindexed document will get returned when using no WHERE clause

   var allDocs = client.CreateDocumentQuery("dbs/mydb/colls/autoindexing",
      "SELECT * FROM c").ToList();
   Console.WriteLine("All documents: {0}", allDocs.Count);
	
   // Unindexed document will get returned when querying by ID (or self-link) property
	
   Document janeDoc = client.CreateDocumentQuery("dbs/mydb/colls/autoindexing",
      "SELECT * FROM c WHERE c.id = 'JANE'").AsEnumerable().FirstOrDefault();
   Console.WriteLine("Unindexed document self-link: {0}", janeDoc.SelfLink);
	
   // Delete the collection
	
   await client.DeleteDocumentCollectionAsync("dbs/mydb/colls/autoindexing");
}

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

लेकिन जब मार्क अपस्टोन के लिए दूसरा दस्तावेज़ जोड़ा जाता है, तो हमने IndexingDirective.Exclude के साथ अनुरोध विकल्प पारित किए हैं, जो स्पष्ट रूप से डॉक्यूमेंटडीबी को निर्देश देता है कि संग्रह की अनुक्रमण नीति के बावजूद, इस दस्तावेज़ को अनुक्रमित न करें।

अंत में दोनों दस्तावेजों के लिए हमारे पास विभिन्न प्रकार के प्रश्न हैं।

Step 3 - CreateDocumentClient से ऑटोमैटिकइंडेक्सिंग कार्य को कॉल करते हैं।

private static async Task CreateDocumentClient() {
   // Create a new instance of the DocumentClient 
   using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) { 
      await AutomaticIndexing(client); 
   } 
}

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

**** Override Automatic Indexing **** 
Documents WHERE lastName = 'Upston': 1 
All documents: 2 
Unindexed document self-link: dbs/kV5oAA==/colls/kV5oAOEkfQA=/docs/kV5oAOEkfQACA 
AAAAAAAAA==/

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

हम उनकी आईडी या सेल्फ-लिंक द्वारा अनइंस्टॉल किए गए दस्तावेजों को भी प्राप्त कर सकते हैं। इसलिए जब हम मार्क के दस्तावेज़ के लिए उसकी ID, MARK से क्वेरी करते हैं, तो हम देखते हैं कि DocumentDB दस्तावेज़ को वापस कर देता है, हालांकि यह संग्रह में अनुक्रमित नहीं है।

मैनुअल अनुक्रमण

स्वचालित अनुक्रमण को ओवरराइड करके मैन्युअल अनुक्रमण के एक सरल उदाहरण पर एक नज़र डालते हैं।

Step 1- पहले हम मैन्युअलइंडेक्सिंग नामक एक संग्रह बनाएंगे और स्वचालित अनुक्रमण को स्पष्ट रूप से अक्षम करके डिफ़ॉल्ट नीति को ओवरराइड करेंगे। इसका मतलब यह है कि, जब तक हम अन्यथा अनुरोध नहीं करते हैं, इस संग्रह में जोड़े गए नए दस्तावेजों को अनुक्रमित नहीं किया जाएगा।

private async static Task ManualIndexing(DocumentClient client) {
   Console.WriteLine();
   Console.WriteLine("**** Manual Indexing ****");
   // Create collection with manual indexing

   var collectionDefinition = new DocumentCollection {
      Id = "manualindexing",
      IndexingPolicy = new IndexingPolicy {
         Automatic = false,
      },
   };
	
   var collection = await client.CreateDocumentCollectionAsync("dbs/mydb",
      collectionDefinition);
		
   // Add a document (unindexed)
   dynamic unindexedDocumentDefinition = new {
      id = "MARK",
      firstName = "Mark",
      lastName = "Doe",
      addressLine = "123 Main Street",
      city = "Brooklyn",
      state = "New York",
      zip = "11229",
   }; 
	
   Document unindexedDocument = await client
      .CreateDocumentAsync("dbs/mydb/colls/manualindexing", unindexedDocumentDefinition);
  
   // Add another document (request indexing)
   dynamic indexedDocumentDefinition = new {
      id = "JANE",
      firstName = "Jane",
      lastName = "Doe",
      addressLine = "123 Main Street",
      city = "Brooklyn",
      state = "New York",
      zip = "11229",
   };
	
   Document indexedDocument = await client.CreateDocumentAsync
      ("dbs/mydb/colls/manualindexing", indexedDocumentDefinition, new RequestOptions {
      IndexingDirective = IndexingDirective.Include });

   //Unindexed document won't get returned when querying on non-ID (or selflink) property

   var doeDocs = client.CreateDocumentQuery("dbs/mydb/colls/manualindexing",
      "SELECT * FROM c WHERE c.lastName = 'Doe'").ToList();
   Console.WriteLine("Documents WHERE lastName = 'Doe': {0}", doeDocs.Count);
	
   // Unindexed document will get returned when using no WHERE clause
	
   var allDocs = client.CreateDocumentQuery("dbs/mydb/colls/manualindexing",
      "SELECT * FROM c").ToList();
   Console.WriteLine("All documents: {0}", allDocs.Count);
	
   // Unindexed document will get returned when querying by ID (or self-link) property
	
   Document markDoc = client
      .CreateDocumentQuery("dbs/mydb/colls/manualindexing",
      "SELECT * FROM c WHERE c.id = 'MARK'")
      .AsEnumerable().FirstOrDefault();
   Console.WriteLine("Unindexed document self-link: {0}", markDoc.SelfLink);
   await client.DeleteDocumentCollectionAsync("dbs/mydb/colls/manualindexing");
}

Step 2- अब हम फिर से पहले की तरह ही दो दस्तावेज बनाएंगे। हम इस बार मार्क के दस्तावेज़ के लिए किसी विशेष अनुरोध विकल्प की आपूर्ति नहीं करेंगे, क्योंकि संग्रह की अनुक्रमण नीति के कारण, इस दस्तावेज़ को अनुक्रमित नहीं किया जाएगा।

Step 3 - अब जब हम मार्क के लिए दूसरा दस्तावेज़ जोड़ते हैं, तो हम IndexingDirective.Include के साथ RequestOptions का उपयोग करके डॉक्यूमेंटीडी को यह बताने के लिए कहते हैं कि इसे इस दस्तावेज़ को अनुक्रमित करना चाहिए, जो संग्रह की अनुक्रमण नीति को ओवरराइड करता है जो कहता है कि इसे नहीं करना चाहिए।

अंत में दोनों दस्तावेजों के लिए हमारे पास विभिन्न प्रकार के प्रश्न हैं।

Step 4 - CreateDocumentClient से ManualIndexing कार्य को कॉल करते हैं।

private static async Task CreateDocumentClient() {
   // Create a new instance of the DocumentClient 
   using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
      await ManualIndexing(client); 
   } 
}

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

**** Manual Indexing **** 
Documents WHERE lastName = 'Upston': 1 
All documents: 2 
Unindexed document self-link: dbs/kV5oAA==/colls/kV5oANHJPgE=/docs/kV5oANHJPgEBA 
AAAAAAAAA==/

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

Microsoft ने जोड़ा geospatial support, जो आपको अपने दस्तावेज़ों में स्थान डेटा संग्रहीत करने और अंकों और बहुभुजों के बीच की दूरी और चौराहों के लिए स्थानिक गणना करने की सुविधा देता है।

  • स्थानिक डेटा अंतरिक्ष में वस्तुओं की स्थिति और आकार का वर्णन करता है।

  • आमतौर पर, इसका उपयोग किसी व्यक्ति के स्थान, रुचि के स्थान, या किसी शहर, या झील की सीमा का प्रतिनिधित्व करने के लिए किया जा सकता है।

  • सामान्य उपयोग के मामलों में अक्सर निकटता प्रश्न शामिल होते हैं। उदाहरण के लिए, "मेरे वर्तमान स्थान के पास सभी विश्वविद्यालय खोजें"।

Pointअंतरिक्ष में एक भी स्थिति को दर्शाता है जो सटीक स्थान का प्रतिनिधित्व करता है, जैसे विशेष विश्वविद्यालय का सड़क का पता। डॉक्यूमेंटडीबी में एक बिंदु को अपनी समन्वित जोड़ी (देशांतर और अक्षांश) का उपयोग करके दर्शाया गया है। निम्नलिखित JSON बिंदु का एक उदाहरण है।

{ 
   "type":"Point", 
   "coordinates":[ 28.3, -10.7 ] 
}

आइए एक सरल उदाहरण देखें, जिसमें एक विश्वविद्यालय का स्थान शामिल है।

{ 
   "id":"case-university", 
   "name":"CASE: Center For Advanced Studies In Engineering", 
   "city":"Islamabad", 
	
   "location": { 
      "type":"Point", 
      "coordinates":[ 33.7194136, -73.0964862 ] 
   } 
}

स्थान के आधार पर विश्वविद्यालय के नाम को पुनः प्राप्त करने के लिए, आप निम्नलिखित क्वेरी का उपयोग कर सकते हैं।

SELECT c.name FROM c 

WHERE c.id = "case-university" AND ST_ISVALID({ 
      "type":"Point", 
      "coordinates":[ 33.7194136, -73.0964862 ]})

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

[ 
   { 
      "name": "CASE: Center For Advanced Studies In Engineering" 
   } 
]

.NET में जियोस्पेशल डेटा के साथ दस्तावेज़ बनाएँ

आप भू-स्थानिक डेटा के साथ एक दस्तावेज़ बना सकते हैं, आइए एक सरल उदाहरण देखें जिसमें एक विश्वविद्यालय दस्तावेज़ बनाया गया है।

private async static Task CreateDocuments(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** Create Documents ****"); 
   Console.WriteLine();
	
   var uniDocument = new UniversityProfile {
      Id = "nust", 
      Name = "National University of Sciences and Technology", 
      City = "Islamabad", 
      Loc = new Point(33.6455715, 72.9903447) 
   };
	
   Document document = await CreateDocument(client, uniDocument); 
   Console.WriteLine("Created document {0} from typed object", document.Id); 
   Console.WriteLine(); 
}

विश्वविद्यालयप्रोफ़ाइल वर्ग के लिए कार्यान्वयन निम्नलिखित है।

public class UniversityProfile { 
   [JsonProperty(PropertyName = "id")] 
   public string Id { get; set; }  
	
   [JsonProperty("name")] 
   public string Name { get; set; }
	
   [JsonProperty("city")] 
   public string City { get; set; }  
	
   [JsonProperty("location")] 
   public Point Loc { get; set; } 
}

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

**** Create Documents ****  
Created new document: nust 
{ 
   "id": "nust", 
   "name": "National University of Sciences and Technology", 
   "city": "Islamabad", 
   "location": { 
      "type": "Point", 
      "coordinates": [ 
         33.6455715, 
         72.9903447 
      ] 
   }, 
   "_rid": "Ic8LAMEUVgANAAAAAAAAAA==", 
   "_ts": 1450200910, 
   "_self": "dbs/Ic8LAA==/colls/Ic8LAMEUVgA=/docs/Ic8LAMEUVgANAAAAAAAAAA==/", 
   "_etag": "\"00004100-0000-0000-0000-56704f4e0000\"", 
   "_attachments": "attachments/" 
} 
Created document nust from typed object

जब आपका डेटाबेस 10GB से आगे बढ़ने लगता है, तो आप बस नए संग्रह बना सकते हैं और फिर अपने डेटा को अधिक से अधिक संग्रह में फैला या विभाजित कर सकते हैं।

जल्दी या बाद में एक एकल संग्रह, जिसमें 10 जीबी की क्षमता है, आपके डेटाबेस को रखने के लिए पर्याप्त नहीं होगा। अब 10GB एक बहुत बड़ी संख्या की तरह नहीं लग सकता है, लेकिन याद रखें कि हम JSON दस्तावेज़ संग्रहीत कर रहे हैं, जो कि केवल सादे पाठ है और आप 10GB में बहुत सारे सादे पाठ दस्तावेज़ फिट कर सकते हैं, तब भी जब आप इंडेक्स के लिए स्टोरेज ओवरहेड पर विचार करते हैं।

स्केलेबिलिटी की बात आने पर स्टोरेज एकमात्र चिंता का विषय नहीं है। एक संग्रह पर उपलब्ध अधिकतम थ्रूपुट प्रति सेकंड ढाई हज़ार अनुरोध इकाइयाँ हैं जो आपको S3 संग्रह के साथ मिलती हैं। इसलिए, यदि आपको उच्च थ्रूपुट की आवश्यकता है, तो आपको कई संग्रह के साथ विभाजन करके भी स्केल करना होगा। स्केल आउट विभाजन को भी कहा जाता हैhorizontal partitioning

कई दृष्टिकोण हैं जिनका उपयोग Azure DocumentDB के साथ डेटा के विभाजन के लिए किया जा सकता है। निम्नलिखित सबसे आम रणनीतियाँ हैं -

  • स्पिलओवर विभाजन
  • श्रेणी विभाजन
  • लुकअप विभाजन
  • हैश विभाजन

स्पिलओवर विभाजन

स्पिलओवर विभाजन एक सरलतम रणनीति है क्योंकि विभाजन कुंजी नहीं है। जब आप बहुत सी चीजों के बारे में अनिश्चित होते हैं, तो इसे शुरू करना एक अच्छा विकल्प है। आप नहीं जान सकते हैं कि क्या आपको कभी भी एक संग्रह से परे स्केल करने की आवश्यकता होगी या आपको कितने संग्रह जोड़ने की आवश्यकता हो सकती है या कितनी तेजी से आपको उन्हें जोड़ने की आवश्यकता हो सकती है।

  • स्पिलओवर विभाजन एक संग्रह के साथ शुरू होता है और कोई विभाजन कुंजी नहीं है।

  • संग्रह बढ़ने लगता है और फिर कुछ और बढ़ता है, और फिर कुछ और, जब तक आप 10GB की सीमा के करीब होना शुरू नहीं करते।

  • जब आप 90 प्रतिशत की क्षमता तक पहुंच जाते हैं, तो आप एक नए संग्रह पर पहुंच जाते हैं और नए दस्तावेजों के लिए इसका उपयोग करना शुरू कर देते हैं।

  • एक बार जब आपका डेटाबेस बड़ी संख्या में संग्रह करने के लिए तैयार हो जाता है, तो आप शायद एक ऐसी रणनीति में बदलाव करना चाहेंगे जो एक विभाजन कुंजी पर आधारित हो।

  • जब आप ऐसा करते हैं, तो आपको जो भी रणनीति आप प्रवास कर रहे हैं, उसके आधार पर दस्तावेज़ों को विभिन्न संग्रहों में ले जाकर अपने डेटा को पुनर्संतुलित करना होगा।

श्रेणी विभाजन

सबसे आम रणनीतियों में से एक श्रेणी विभाजन है। इस दृष्टिकोण से आप उन मानों की सीमा निर्धारित करते हैं जो किसी दस्तावेज़ की विभाजन कुंजी में गिर सकते हैं और दस्तावेज़ को उस श्रेणी के अनुरूप संग्रह में निर्देशित कर सकते हैं।

  • तिथियाँ आमतौर पर इस रणनीति के साथ उपयोग की जाती हैं जहाँ आप दस्तावेजों को रखने के लिए एक संग्रह बनाते हैं जो कि निर्धारित सीमा के भीतर आते हैं। जब आप उन सीमाओं को परिभाषित करते हैं जो काफी छोटे होते हैं, जहां आप आश्वस्त होते हैं कि कोई संग्रह कभी भी इसकी 10GB की सीमा से अधिक नहीं होगा। उदाहरण के लिए, एक परिदृश्य हो सकता है जहां एक संग्रह पूरे महीने के लिए दस्तावेजों को यथोचित रूप से संभाल सकता है।

  • यह भी हो सकता है कि अधिकांश उपयोगकर्ता वर्तमान डेटा के लिए क्वेरी कर रहे हों, जो इस महीने या शायद पिछले महीने के लिए डेटा होगा, लेकिन उपयोगकर्ता शायद ही कभी पुराने डेटा की खोज कर रहे हों। तो आप जून में एक S3 संग्रह के साथ शुरू करते हैं, जो कि सबसे महंगा संग्रह है जिसे आप खरीद सकते हैं और सबसे अच्छा थ्रूपुट प्राप्त कर सकते हैं।

  • जुलाई में आप जुलाई के डेटा को स्टोर करने के लिए एक और S3 संग्रह खरीदते हैं और आप जून के डेटा को एक कम-महंगे S2 संग्रह में स्केल करते हैं। फिर अगस्त में, आपको एक एस 2 संग्रह और स्केल जुलाई डाउन टू एस 2 और जून सभी तरह से एस 1 नीचे मिलता है। यह महीने-दर-महीने आगे बढ़ता है, जहाँ आप हमेशा मौजूदा डेटा को उच्च थ्रूपुट के लिए उपलब्ध रखते हैं और पुराने डेटा को निम्न थ्रूपुट में उपलब्ध रखते हैं।

  • जब तक क्वेरी एक विभाजन कुंजी प्रदान करती है, तब तक केवल उस संग्रह को क्वेर करने की आवश्यकता होती है, जो डेटाबेस में सभी संग्रह नहीं होता है, जैसे कि स्पिलओवर विभाजन के साथ होता है।

लुकअप विभाजन

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

  • एक संग्रह में सभी अमेरिकी दस्तावेजों को स्टोर करें, दूसरे संग्रह में सभी यूरोपीय दस्तावेजों और तीसरे संग्रह में किसी अन्य क्षेत्र के सभी दस्तावेजों को संग्रहीत करें।

  • इस पार्टीशन मैप का उपयोग करें और लुकअप पार्टीशन रिज़ॉल्वर यह पता लगा सकता है कि किस पार्टीशन में डॉक्यूमेंट बनाने के लिए कौन सा कलेक्शन और किस कलेक्शन को क्वैरी करना है, जो कि पार्टिशन प्रॉपर्टी के आधार पर है, जो प्रत्येक डॉक्यूमेंट में निहित है।

हैश विभाजन

हैश विभाजन में, विभाजन एक हैश फ़ंक्शन के मान के आधार पर असाइन किए जाते हैं, जिससे आप कई विभाजनों में समान रूप से अनुरोध और डेटा वितरित कर सकते हैं।

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

आइए .NET SDK द्वारा आपूर्ति की गई RangePartitionResolver का उपयोग करके श्रेणी विभाजन के एक सरल उदाहरण पर एक नज़र डालते हैं।

Step 1- एक नया दस्तावेज़ बनाएँ और हम CreateCollections कार्य में दो संग्रह बनाएंगे। एक में उन उपयोगकर्ताओं के लिए दस्तावेज़ होंगे जिनके पास उपयोगकर्ता आईडी एम के माध्यम से शुरू होता है और दूसरा उपयोगकर्ता आईडी एन के लिए जेड के माध्यम से होता है।

private static async Task CreateCollections(DocumentClient client) {
   await client.CreateDocumentCollectionAsync(“dbs/myfirstdb”, new DocumentCollection {
      Id = “CollectionAM” }); 
		
   await client.CreateDocumentCollectionAsync(“dbs/myfirstdb”, new DocumentCollection {
      Id = “CollectionNZ” }); 
}

Step 2 - डेटाबेस के लिए रेंज रिज़ॉल्वर पंजीकृत करें।

Step 3- एक नया RangePartitionResolver <string> बनाएँ, जो हमारे विभाजन कुंजी का डेटाटाइप है। कंस्ट्रक्टर दो मापदंडों को लेता है, विभाजन कुंजी का गुणक नाम और एक शब्दकोश जो कि शार्प मैप या पार्टीशन मैप है, जो सिर्फ श्रेणियों और संबंधित संग्रहों की एक सूची है जिसे हम रिज़ॉल्वर के लिए पूर्वनिर्धारित कर रहे हैं।

private static void RegisterRangeResolver(DocumentClient client) {

   //Note: \uffff is the largest UTF8 value, so M\ufff includes all strings that start with M.
		
   var resolver = new RangePartitionResolver<string>(
      "userId", new Dictionary<Range<string>, string>() {
      { new Range<string>("A", "M\uffff"), "dbs/myfirstdb/colls/CollectionAM" },
      { new Range<string>("N", "Z\uffff"), "dbs/myfirstdb/colls/CollectionNZ" },
   });
	
   client.PartitionResolvers["dbs/myfirstdb"] = resolver;
 }

यहां सबसे बड़े संभावित UTF-8 मान को एनकोड करना आवश्यक है। या फिर पहली रेंज एक सिंगल M को छोड़कर किसी भी Ms पर मेल नहीं खाएगी, और इसी तरह दूसरी रेंज में Z के लिए। इसलिए, आप इस एन्कोडेड वैल्यू के बारे में यहाँ विभाजन कुंजी पर मिलान के लिए वाइल्डकार्ड के रूप में सोच सकते हैं।

Step 4- रिज़ॉल्वर बनाने के बाद, इसे वर्तमान DocumentClient के साथ डेटाबेस के लिए पंजीकृत करें। ऐसा करने के लिए बस इसे PartitionResolver की डिक्शनरी प्रॉपर्टी को असाइन करें।

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

अब कुछ दस्तावेज बनाते हैं। पहले हम userId Kirk के लिए एक बनाएँगे, और फिर Spock के लिए एक।

private static async Task CreateDocumentsAcrossPartitions(DocumentClient client) { 
   Console.WriteLine(); 
   Console.WriteLine("**** Create Documents Across Partitions ****");
	
   var kirkDocument = await client.CreateDocumentAsync("dbs/myfirstdb", new { userId =
      "Kirk", title = "Captain" }); 
   Console.WriteLine("Document 1: {0}", kirkDocument.Resource.SelfLink);
	
   var spockDocument = await client.CreateDocumentAsync("dbs/myfirstdb", new { userId =
      "Spock", title = "Science Officer" });		
   Console.WriteLine("Document 2: {0}", spockDocument.Resource.SelfLink); 
}

यहां पहला पैरामीटर डेटाबेस का एक स्व-लिंक है, न कि एक विशिष्ट संग्रह। यह एक विभाजन रिज़ॉल्वर के बिना संभव नहीं है, लेकिन एक के साथ यह सिर्फ मूल रूप से काम करता है।

दोनों दस्तावेजों को डेटाबेस myfirstdb में सहेजा गया था, लेकिन हम जानते हैं कि Kirk को A के लिए M के माध्यम से संग्रह में संग्रहीत किया जा रहा है और Sp को N से Z के लिए संग्रह में संग्रहीत किया जा रहा है, यदि हमारी RangePartitionResolver ठीक से काम कर रही है।

निम्न कोड में दिखाए गए अनुसार CreateDocumentClient कार्य से कॉल करते हैं।

private static async Task CreateDocumentClient() {
   // Create a new instance of the DocumentClient 
   using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
      await CreateCollections(client);  
      RegisterRangeResolver(client);  
      await CreateDocumentsAcrossPartitions(client); 
   } 
}

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

**** Create Documents Across Partitions **** 
Document 1: dbs/Ic8LAA==/colls/Ic8LAO2DxAA=/docs/Ic8LAO2DxAABAAAAAAAAAA==/ 
Document 2: dbs/Ic8LAA==/colls/Ic8LAP12QAE=/docs/Ic8LAP12QAEBAAAAAAAAAA==/

जैसा कि देखा गया है कि दो दस्तावेजों के स्व-लिंक में अलग-अलग संसाधन आईडी हैं, क्योंकि वे दो अलग-अलग संग्रह में मौजूद हैं।

DocumentDB डेटा माइग्रेशन टूल के साथ, आप आसानी से DocumentDB पर डेटा माइग्रेट कर सकते हैं। DocumentDB डेटा माइग्रेशन टूल एक मुफ्त और खुला स्रोत उपयोगिता है जिसे आप Microsoft डाउनलोड केंद्र से डाउनलोड कर सकते हैंhttps://www.microsoft.com/

माइग्रेशन टूल कई डेटा स्रोतों का समर्थन करता है, उनमें से कुछ नीचे सूचीबद्ध हैं -

  • एस क्यू एल सर्वर
  • JSON फ़ाइलें
  • कोमा से अलग किए गए मूल्यों की फ्लैट फाइलें (CSV)
  • MongoDB
  • एज़्योर टेबल स्टोरेज
  • Amazon DynamoDB
  • HBase, और यहां तक ​​कि अन्य DocumentDB डेटाबेस

DocumentDB डेटा माइग्रेशन टूल डाउनलोड करने के बाद, ज़िप फ़ाइल को निकालें।

आप इस फ़ोल्डर में दो निष्पादन योग्य देख सकते हैं जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

सबसे पहले, dt.exe है, जो एक कमांड लाइन इंटरफेस के साथ कंसोल संस्करण है, और फिर dtui.exe है, जो एक ग्राफिकल यूजर इंटरफेस के साथ डेस्कटॉप संस्करण है।

जीयूआई संस्करण लॉन्च करते हैं।

आप स्वागत पृष्ठ देख सकते हैं। स्रोत जानकारी पृष्ठ के लिए 'अगला' पर क्लिक करें।

यहां आप अपने डेटा स्रोत को कॉन्फ़िगर करते हैं, और आप ड्रॉपडाउन मेनू से कई समर्थित विकल्प देख सकते हैं।

जब आप कोई चयन करते हैं, तो शेष स्रोत सूचना पृष्ठ उसी के अनुसार बदलते हैं।

डॉक्यूमेंटीडीबी डेटा माइग्रेशन टूल का उपयोग करके डॉक्यूमेंटडीबी में डेटा आयात करना बहुत आसान है। हम आपको उपरोक्त उदाहरणों का उपयोग करने और अन्य डेटा फ़ाइलों का उपयोग करने की सलाह देते हैं।

डॉक्यूमेंटडीबी कॉन्सेप्ट्स को डॉक्यूबीडी संसाधनों तक पहुंच को नियंत्रित करने के लिए प्रदान करता है। DocumentDB संसाधनों तक पहुंच एक मास्टर कुंजी टोकन या एक संसाधन टोकन द्वारा शासित है। संसाधन टोकन के आधार पर कनेक्शन केवल टोकन द्वारा निर्दिष्ट संसाधनों तक पहुंच सकते हैं और कोई अन्य संसाधन नहीं। संसाधन टोकन उपयोगकर्ता की अनुमति पर आधारित होते हैं।

  • पहले आप एक या अधिक उपयोगकर्ता बनाते हैं, और ये डेटाबेस स्तर पर परिभाषित होते हैं।

  • फिर आप प्रत्येक उपयोगकर्ता के लिए एक या एक से अधिक अनुमतियाँ बनाते हैं, उन संसाधनों के आधार पर जिन्हें आप प्रत्येक उपयोगकर्ता तक पहुँचने की अनुमति देना चाहते हैं।

  • प्रत्येक अनुमति एक संसाधन टोकन उत्पन्न करती है जो किसी दिए गए संसाधन तक या तो केवल-पढ़ने या पूर्ण पहुँच की अनुमति देता है और डेटाबेस के भीतर कोई भी उपयोगकर्ता संसाधन हो सकता है।

  • उपयोगकर्ताओं को डेटाबेस स्तर पर परिभाषित किया गया है और प्रत्येक उपयोगकर्ता के लिए अनुमतियाँ परिभाषित की गई हैं।

  • उपयोगकर्ता और अनुमतियाँ डेटाबेस में सभी संग्रहों पर लागू होती हैं।

आइए एक सरल उदाहरण देखें, जिसमें हम सीखेंगे कि डॉक्यूमेंटीडी में उपयोगकर्ताओं और अनुमतियों को कैसे परिभाषित किया जाए।

हम myfirstdb डेटाबेस के लिए एक नया DocumentClient और क्वेरी के साथ शुरू करेंगे।

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();
			
      var alice = await CreateUser(client, "Alice");
      var tom = await CreateUser(client, "Tom");
   }
}

निम्नलिखित CreateUser के लिए कार्यान्वयन है।

private async static Task<User> CreateUser(DocumentClient client, string userId) {
   Console.WriteLine();
   Console.WriteLine("**** Create User {0} in {1} ****", userId, database.Id);
	
   var userDefinition = new User { Id = userId };
   var result = await client.CreateUserAsync(database.SelfLink, userDefinition);
   var user = result.Resource;
	
   Console.WriteLine("Created new user");
   ViewUser(user);
	
   return user;
}

Step 1- दो उपयोगकर्ता, ऐलिस और टॉम जैसे कोई भी संसाधन जो हम बनाते हैं, हम वांछित आईडी के साथ एक परिभाषा ऑब्जेक्ट का निर्माण करते हैं और निर्माण विधि को कॉल करते हैं और इस मामले में हम CreateUserAsync को डेटाबेस के SelfLink और userDefinition के साथ कॉल कर रहे हैं। हमें वह परिणाम वापस मिल जाता है जिसकी संसाधन संपत्ति से हम नव निर्मित उपयोगकर्ता वस्तु प्राप्त करते हैं।

अब डेटाबेस में इन दो नए उपयोगकर्ताओं को देखने के लिए।

private static void ViewUsers(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** View Users in {0} ****", database.Id);  
	
   var users = client.CreateUserQuery(database.UsersLink).ToList();
   var i = 0;
	
   foreach (var user in users) { 
      i++; 
      Console.WriteLine(); 
      Console.WriteLine("User #{0}", i); 
      ViewUser(user); 
   }
	
   Console.WriteLine();
   Console.WriteLine("Total users in database {0}: {1}", database.Id, users.Count); 
}
  
private static void ViewUser(User user) {
   Console.WriteLine("User ID: {0} ", user.Id); 
   Console.WriteLine("Resource ID: {0} ", user.ResourceId); 
   Console.WriteLine("Self Link: {0} ", user.SelfLink); 
   Console.WriteLine("Permissions Link: {0} ", user.PermissionsLink); 
   Console.WriteLine("Timestamp: {0} ", user.Timestamp); 
}

Step 2- सभी उपयोगकर्ताओं की एक सूची को पुनः प्राप्त करने के लिए डेटाबेस के UsersLink के खिलाफ CreateUUserQuery को कॉल करें। फिर उनके माध्यम से लूप करें और उनके गुणों को देखें।

अब हमें उन्हें पहले बनाना होगा। तो मान लीजिए कि हम ऐलिस को MyCollection संग्रह को पढ़ने / लिखने की अनुमति देना चाहते थे, लेकिन टॉम केवल संग्रह में दस्तावेज़ पढ़ सकते हैं।

await CreatePermission(client, alice, "Alice Collection Access", PermissionMode.All,
   collection);
	
await CreatePermission(client, tom, "Tom Collection Access", PermissionMode.Read,
   collection);

Step 3- एक संसाधन पर एक अनुमति बनाएँ जो MyCollection संग्रह है इसलिए हमें उस संसाधन को एक SelfLink प्राप्त करने की आवश्यकता है।

Step 4 - इसके बाद एक परमिशन बनाएं। एलिस और एक परमिशन के लिए इस कलेक्शन पर जाएं। टॉम के लिए इस कलेक्शन पर जाएं।

निम्नलिखित CreatePermission के लिए कार्यान्वयन है।

private async static Task CreatePermission(DocumentClient client, User user,
   string permId, PermissionMode permissionMode, string resourceLink) {
   Console.WriteLine();
   Console.WriteLine("**** Create Permission {0} for {1} ****", permId, user.Id);
	
   var permDefinition = new Permission {
      Id = permId,
      PermissionMode = permissionMode,
      ResourceLink = resourceLink
   };
	
   var result = await client.CreatePermissionAsync(user.SelfLink, permDefinition);
   var perm = result.Resource;
   Console.WriteLine("Created new permission");
   ViewPermission(perm);
}

जैसा कि आप अब तक उम्मीद करने के लिए आना चाहिए, हम नई अनुमति के लिए एक परिभाषा ऑब्जेक्ट बनाकर ऐसा करते हैं, जिसमें एक आईडी और एक अनुमति शामिल है, जो या तो Permission.All या Permission.Read है, और उस संसाधन के SelfLink को सुरक्षित किया जा रहा है अनुमति से।

Step 5 - CreatePermissionAsync को कॉल करें और परिणाम में संसाधन संपत्ति से बनाई गई अनुमति प्राप्त करें।

बनाई गई अनुमति को देखने के लिए, ViewPims का कार्यान्वयन निम्नलिखित है।

private static void ViewPermissions(DocumentClient client, User user) {
   Console.WriteLine(); 
   Console.WriteLine("**** View Permissions for {0} ****", user.Id);
	
   var perms = client.CreatePermissionQuery(user.PermissionsLink).ToList();
   var i = 0; 
	
   foreach (var perm in perms) {
      i++; 
      Console.WriteLine(); 
      Console.WriteLine("Permission #{0}", i); 
      ViewPermission(perm); 
   }  
	
   Console.WriteLine(); 
   Console.WriteLine("Total permissions for {0}: {1}", user.Id, perms.Count); 
}
  
private static void ViewPermission(Permission perm) {
   Console.WriteLine("Permission ID: {0} ", perm.Id); 
   Console.WriteLine("Resource ID: {0} ", perm.ResourceId); 
   Console.WriteLine("Permission Mode: {0} ", perm.PermissionMode);
   Console.WriteLine("Token: {0} ", perm.Token); 
   Console.WriteLine("Timestamp: {0} ", perm.Timestamp); 
}

इस बार, यह उपयोगकर्ता की अनुमति लिंक के खिलाफ एक अनुमति क्वेरी है और हम बस उपयोगकर्ता के लिए लौटे प्रत्येक अनुमति को सूचीबद्ध करते हैं।

चलो ऐलिस और टॉम की अनुमति को हटा दें।

await DeletePermission(client, alice, "Alice Collection Access"); 
await DeletePermission(client, tom, "Tom Collection Access");

निम्नलिखित DeletePermission के लिए कार्यान्वयन है।

private async static Task DeletePermission(DocumentClient client, User user,
   string permId) {
   Console.WriteLine(); 
   Console.WriteLine("**** Delete Permission {0} from {1} ****", permId, user.Id);
	
   var query = new SqlQuerySpec {
      QueryText = "SELECT * FROM c WHERE c.id = @id", 
      Parameters = new SqlParameterCollection {
         new SqlParameter { Name = "@id", Value = permId }
      } 
   };
	
   Permission perm = client.CreatePermissionQuery(user.PermissionsLink, query)
      .AsEnumerable().First();  
   await client.DeletePermissionAsync(perm.SelfLink);  
   Console.WriteLine("Deleted permission {0} from user {1}", permId, user.Id); 
}

Step 6 - अनुमतियों को हटाने के लिए, SelfLink पाने के लिए अनुमति क्रमांक द्वारा क्वेरी करें, और फिर अनुमति को हटाने के लिए SelfLink का उपयोग करें।

इसके बाद, उपयोगकर्ताओं को स्वयं हटा दें। चलो दोनों उपयोगकर्ताओं को हटा दें।

await DeleteUser(client, "Alice"); 
await DeleteUser(client, "Tom");

निम्नलिखित DeleteUser के लिए कार्यान्वयन है।

private async static Task DeleteUser(DocumentClient client, string userId) {
   Console.WriteLine(); 
   Console.WriteLine("**** Delete User {0} in {1} ****", userId, database.Id);
	
   var query = new SqlQuerySpec { 
      QueryText = "SELECT * FROM c WHERE c.id = @id", 
      Parameters = new SqlParameterCollection {
         new SqlParameter { Name = "@id", Value = userId }
      } 
   };
	
   User user = client.CreateUserQuery(database.SelfLink, query).AsEnumerable().First();  
   await client.DeleteUserAsync(user.SelfLink);  
   Console.WriteLine("Deleted user {0} from database {1}", userId, database.Id); 
}

Step 7 - पहले सेल्फलिंक पाने के लिए पहले क्वेरी करें और उसके बाद DeleteUserAsync को कॉल करें ताकि उसकी यूजर ऑब्जेक्ट डिलीट हो सके।

निम्नलिखित 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();
			
      ViewUsers(client);
		
      var alice = await CreateUser(client, "Alice");
      var tom = await CreateUser(client, "Tom");
      ViewUsers(client);
		
      ViewPermissions(client, alice);
      ViewPermissions(client, tom);
		
      string collectionLink = client.CreateDocumentCollectionQuery(database.SelfLink,
         "SELECT VALUE c._self FROM c WHERE c.id = 'MyCollection'")
         .AsEnumerable().First().Value;
			
      await CreatePermission(client, alice, "Alice Collection Access", PermissionMode.All,
         collectionLink);
			
      await CreatePermission(client, tom, "Tom Collection Access", PermissionMode.Read,
         collectionLink);
			
      ViewPermissions(client, alice);
      ViewPermissions(client, tom);
		
      await DeletePermission(client, alice, "Alice Collection Access");
      await DeletePermission(client, tom, "Tom Collection Access");
		
      await DeleteUser(client, "Alice");
      await DeleteUser(client, "Tom");
   }
}

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

**** View Users in myfirstdb **** 
 
Total users in database myfirstdb: 0 
 
**** Create User Alice in myfirstdb **** 
Created new user 
          User ID: Alice 
      Resource ID: kV5oAC56NwA= 
        Self Link: dbs/kV5oAA==/users/kV5oAC56NwA=/ 
 Permissions Link: dbs/kV5oAA==/users/kV5oAC56NwA=/permissions/ 
        Timestamp: 12/17/2015 5:44:19 PM
		  
**** Create User Tom in myfirstdb **** 
Created new user 
          User ID: Tom 
      Resource ID: kV5oAALxKgA= 
        Self Link: dbs/kV5oAA==/users/kV5oAALxKgA=/ 
 Permissions Link: dbs/kV5oAA==/users/kV5oAALxKgA=/permissions/ 
        Timestamp: 12/17/2015 5:44:21 PM
		  
**** View Users in myfirstdb ****
  
User #1 
          User ID: Tom 
      Resource ID: kV5oAALxKgA= 
        Self Link: dbs/kV5oAA==/users/kV5oAALxKgA=/ 
 Permissions Link: dbs/kV5oAA==/users/kV5oAALxKgA=/permissions/ 
        Timestamp: 12/17/2015 5:44:21 PM 
		  
User #2 
          User ID: Alice 
      Resource ID: kV5oAC56NwA= 
        Self Link: dbs/kV5oAA==/users/kV5oAC56NwA=/ 
 Permissions Link: dbs/kV5oAA==/users/kV5oAC56NwA=/permissions/ 
        Timestamp: 12/17/2015 5:44:19 PM
		  
Total users in database myfirstdb: 2
  
**** View Permissions for Alice **** 
 
Total permissions for Alice: 0  

**** View Permissions for Tom **** 
 
Total permissions for Tom: 0  

**** Create Permission Alice Collection Access for Alice **** 
Created new permission 
    Permission ID: Alice Collection Access 
      Resource ID: kV5oAC56NwDON1RduEoCAA== 
  Permission Mode: All
            Token: type=resource&ver=1&sig=zB6hfvvleC0oGGbq5cc67w==;Zt3Lx 
Ol14h8pd6/tyF1h62zbZKk9VwEIATIldw4ZyipQGW951kirueAKdeb3MxzQ7eCvDfvp7Y/ZxFpnip/D G 
JYcPyim5cf+dgLvos6fUuiKSFSul7uEKqp5JmJqUCyAvD7w+qt1Qr1PmrJDyAIgbZDBFWGe2VT9FaBH o 
PYwrLjRlnH0AxfbrR+T/UpWMSSHtLB8JvNFZNSH8hRjmQupuTSxCTYEC89bZ/pS6fNmNg8=; 
        Timestamp: 12/17/2015 5:44:28 PM
		  
**** Create Permission Tom Collection Access for Tom **** 
Created new permission 
    Permission ID: Tom Collection Access 
      Resource ID: kV5oAALxKgCMai3JKWdfAA== 
  Permission Mode: Read 
            Token: type=resource&ver=1&sig=ieBHKeyi6EY9ZOovDpe76w==;92gwq 
V4AxKaCJ2dLS02VnJiig/5AEbPcfo1xvOjR10uK3a3FUMFULgsaK8nzxdz6hLVCIKUj6hvMOTOSN8Lt 7 
i30mVqzpzCfe7JO3TYSJEI9D0/5HbMIEgaNJiCu0JPPwsjVecTytiLN56FHPguoQZ7WmUAhVTA0IMP6 p 
jQpLDgJ43ZaG4Zv3qWJiO689balD+egwiU2b7RICH4j6R66UVye+GPxq/gjzqbHwx79t54=; 
        Timestamp: 12/17/2015 5:44:30 PM
		  
**** View Permissions for Alice ****
  
Permission #1 
    Permission ID: Alice Collection Access 
      Resource ID: kV5oAC56NwDON1RduEoCAA== 
  Permission Mode: All 
            Token: type=resource&ver=1&sig=BSzz/VNe9j4IPJ9M31Mf4Q==;Tcq/B 
X50njB1vmANZ/4aHj/3xNkghaqh1OfV95JMi6j4v7fkU+gyWe3mJasO3MJcoop9ixmVnB+RKOhFaSxE l 
P37SaGuIIik7GAWS+dcEBWglMefc95L2YkeNuZsjmmW5b+a8ELCUg7N45MKbpzkp5BrmmGVJ7h4Z4pf D 
rdmehYLuxSPLkr9ndbOOrD8E3bux6TgXCsgYQscpIlJHSKCKHUHfXWBP2Y1LV2zpJmRjis=; 
        Timestamp: 12/17/2015 5:44:28 PM
		  
Total permissions for Alice: 1
  
**** View Permissions for Tom ****
Permission #1 
    Permission ID: Tom Collection Access 
      Resource ID: kV5oAALxKgCMai3JKWdfAA== 
  Permission Mode: Read 
            Token: type=resource&ver=1&sig=NPkWNJp1mAkCASE8KdR6PA==;ur/G2 
V+fDamBmzECux000VnF5i28f8WRbPwEPxD1DMpFPqYcu45wlDyzT5A5gBr3/R3qqYkEVn8bU+een6Gl j 
L6vXzIwsZfL12u/1hW4mJT2as2PWH3eadry6Q/zRXHAxV8m+YuxSzlZPjBFyJ4Oi30mrTXbBAEafZhA 5 
yvbHkpLmQkLCERy40FbIFOzG87ypljREpwWTKC/z8RSrsjITjAlfD/hVDoOyNJwX3HRaz4=; 
        Timestamp: 12/17/2015 5:44:30 PM
		  
Total permissions for Tom: 1
  
**** Delete Permission Alice Collection Access from Alice **** 
Deleted permission Alice Collection Access from user Alice
  
**** Delete Permission Tom Collection Access from Tom **** 
Deleted permission Tom Collection Access from user Tom
  
**** Delete User Alice in myfirstdb **** 
Deleted user Alice from database myfirstdb
  
**** Delete User Tom in myfirstdb **** 
Deleted user Tom from database myfirstdb

इस अध्याय में, हम सीखेंगे कि डेटा की कल्पना कैसे की जाए जो डॉक्यूमेंटीडीबी में संग्रहीत है। Microsoft ने Power BI डेस्कटॉप उपकरण प्रदान किया है जो आपके डेटा को समृद्ध दृश्यों में बदल देता है। यह आपको विभिन्न डेटा स्रोतों से डेटा प्राप्त करने, डेटा को मर्ज करने और बदलने, शक्तिशाली रिपोर्ट और विज़ुअलाइज़ेशन बनाने और पावर बीआई को रिपोर्ट प्रकाशित करने में भी सक्षम बनाता है।

Power BI डेस्कटॉप के नवीनतम संस्करण में, Microsoft ने DocumentDB के लिए समर्थन जोड़ा है, जिसमें अब आप अपने DocumentDB खाते से जुड़ सकते हैं। आप इस टूल को लिंक से डाउनलोड कर सकते हैं,https://powerbi.microsoft.com

आइए एक उदाहरण देखें, जिसमें हम अंतिम अध्याय में आयातित भूकंप के आंकड़ों की कल्पना करेंगे।

Step 1 - टूल डाउनलोड होने के बाद, Power BI डेस्कटॉप लॉन्च करें।

Step 2 - 'डेटा प्राप्त करें' विकल्प पर क्लिक करें, जो बाहरी डेटा समूह के तहत होम टैब पर है और यह गेट डेटा पेज प्रदर्शित करेगा।

Step 3 - Microsoft Azure DocumentDB (बीटा) विकल्प चुनें और 'कनेक्ट' बटन पर क्लिक करें।

Step 4 - अपने Azure DocumentDB खाते, डेटाबेस और संग्रह का URL दर्ज करें जिससे आप डेटा की कल्पना करना चाहते हैं और ओके दबाएं।

यदि आप पहली बार इस समापन बिंदु से जुड़ रहे हैं, तो आपको खाता कुंजी के लिए संकेत दिया जाएगा।

Step 5 - खाता कुंजी (प्राथमिक कुंजी) दर्ज करें जो Azure पोर्टल पर उपलब्ध प्रत्येक DocumentDB खाते के लिए अद्वितीय है, और फिर कनेक्ट पर क्लिक करें।

जब खाता सफलतापूर्वक जुड़ा होता है, तो यह निर्दिष्ट डेटाबेस से डेटा को पुनः प्राप्त करेगा। पूर्वावलोकन फलक रिकॉर्ड आइटमों की एक सूची दिखाती है, दस्तावेज़ को Power BI में रिकॉर्ड प्रकार के रूप में दर्शाया जाता है।

Step 6 - 'संपादन' बटन पर क्लिक करें जो क्वेरी संपादक लॉन्च करेगा।

Step 7 - Power BI क्वेरी संपादक में, आपको केंद्र फलक में एक दस्तावेज़ स्तंभ देखना चाहिए, दस्तावेज़ स्तंभ शीर्ष लेख के दाईं ओर विस्तारक पर क्लिक करें और उन स्तंभों का चयन करें जिन्हें आप प्रदर्शन चाहते हैं।

जैसा कि आप देख सकते हैं कि हमारे पास अक्षांश और देशांतर अलग-अलग कॉलम के रूप में हैं, लेकिन हम अक्षांश में डेटा को देखते हैं, देशांतर निर्देशांक बनाते हैं।

Step 8 - ऐसा करने के लिए, 'कॉलम जोड़ें' टैब पर क्लिक करें।

Step 9 - जोड़ें कस्टम कॉलम का चयन करें जो निम्न पृष्ठ प्रदर्शित करेगा।

Step 10- नए कॉलम का नाम निर्दिष्ट करें, मान लें कि लैटलॉन्ग और वह फॉर्मूला भी है जो अल्पविराम द्वारा अलग किए गए एक कॉलम में अक्षांश और देशांतर को मिलाएगा। इसके बाद सूत्र है।

Text.From([latitude])&", "&Text.From([longitude])

Step 11 - जारी रखने के लिए ओके पर क्लिक करें और आप देखेंगे कि नया कॉलम जुड़ गया है।

Step 12 - होम टैब पर जाएं और & क्लोज एंड अप्लाई ’विकल्प पर क्लिक करें।

Step 13- आप रिपोर्ट कैनवास में फ़ील्ड को खींचकर और छोड़ कर रिपोर्ट बना सकते हैं। आप दाईं ओर देख सकते हैं, दो फलक हैं - एक विज़ुअलाइज़ेशन फलक और दूसरा फ़ील्ड्स फलक है।

आइए प्रत्येक भूकंप के स्थान को दर्शाते हुए एक मानचित्र दृश्य बनाएं।

Step 14 - विज़ुअलाइज़ेशन फलक से नक्शा दृश्य प्रकार खींचें।

Step 15- अब, विज़ुअलाइज़ेशन फलक में फ़ील्ड फ़ील्ड से फलक फ़ील्ड को खींचें और ड्रॉप करें। फिर, मान फ़ील्ड को मान संपत्ति में खींचें और छोड़ें।

Step 16 - रंग संतृप्ति संपत्ति के लिए गहराई क्षेत्र खींचें और छोड़ें।

अब आप मानचित्र दृश्य को बुलबुले का एक सेट दिखाते हुए देखेंगे जो प्रत्येक भूकंप के स्थान को दर्शाता है।