DocumentDB - दस्तावेज़ डालें

इस अध्याय में, हमें एक संग्रह में वास्तविक दस्तावेजों के साथ काम करना होगा। आप 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 ने हमारे लिए नए दस्तावेज़ के लिए इसे तैयार किया है।