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