ओरिएंटबीडी - मूल अवधारणाओं
ओरिएंटबीडी की मुख्य विशेषता मल्टी-मॉडल ऑब्जेक्ट्स का समर्थन करना है, अर्थात यह दस्तावेज़, ग्राफ़, कुंजी / मूल्य और वास्तविक वस्तु जैसे विभिन्न मॉडलों का समर्थन करता है। इसमें इन सभी चार मॉडलों का समर्थन करने के लिए एक अलग एपीआई है।
दस्तावेज़ मॉडल
शब्दावली दस्तावेज़ मॉडल NoSQL डेटाबेस से संबंधित है। इसका अर्थ है कि डेटा दस्तावेज़ों में संग्रहीत है और दस्तावेज़ों के समूह को कहा जाता हैCollection। तकनीकी रूप से, दस्तावेज़ का अर्थ है कुंजी / मूल्य जोड़े का एक सेट या जिसे फ़ील्ड या गुण भी कहा जाता है।
ओरिएंटबैंक अवधारणाओं, जैसे वर्गों, समूहों, और दस्तावेजों के भंडारण, समूहन और विश्लेषण के लिए लिंक का उपयोग करता है।
निम्न तालिका संबंधपरक मॉडल, दस्तावेज़ मॉडल और ओरिएंटडीबी दस्तावेज़ मॉडल के बीच तुलना को दर्शाती है -
संबंधपरक मॉडल | दस्तावेज़ मॉडल | OrientDB दस्तावेज़ मॉडल |
---|---|---|
टेबल | संग्रह | कक्षा या क्लस्टर |
पंक्ति | डाक्यूमेंट | डाक्यूमेंट |
स्तंभ | कुंजी / मूल्य जोड़ी | दस्तावेज़ फ़ील्ड |
संबंध | उपलब्ध नहीं है | संपर्क |
ग्राफ मॉडल
एक ग्राफ डेटा संरचना एक डेटा मॉडल है जो एजेस (आर्क) द्वारा परस्पर कार्यक्षेत्र (नोड्स) के रूप में डेटा को स्टोर कर सकता है। ओरिएंटडीबी ग्राफ डेटाबेस का विचार संपत्ति ग्राफ से आया था। शीर्ष और किनारे ग्राफ़ मॉडल की मुख्य कलाकृतियाँ हैं। वे गुण होते हैं, जो इन दस्तावेजों के समान दिखाई दे सकते हैं।
निम्न तालिका ग्राफ़ मॉडल, संबंधपरक डेटा मॉडल और ओरिएंटबीडी ग्राफ़ मॉडल के बीच तुलना दिखाती है।
संबंधपरक मॉडल | ग्राफ मॉडल | ओरिएंटडीबी ग्राफ मॉडल |
---|---|---|
टेबल | वर्टेक्स और एज क्लास | वर्ग जो "V" (वर्टेक्स के लिए) और "E" (किनारों के लिए) का विस्तार करता है |
पंक्ति | शिखर | शिखर |
स्तंभ | वर्टेक्स और एज प्रॉपर्टी | वर्टेक्स और एज प्रॉपर्टी |
संबंध | एज | एज |
की / मूल्य मॉडल
की / वैल्यू मॉडल का मतलब है कि डेटा को की / वैल्यू पेयर के रूप में स्टोर किया जा सकता है जहां मान सरल और जटिल प्रकार के हो सकते हैं। यह मूल्यों के रूप में दस्तावेजों और ग्राफ तत्वों का समर्थन कर सकता है।
निम्न तालिका संबंधपरक मॉडल, कुंजी / मूल्य मॉडल और ओरिएंटबीडी कुंजी / मूल्य मॉडल के बीच तुलना को दर्शाती है।
संबंधपरक मॉडल | कुंजी / मूल्य मॉडल | ओरिएंटबीडी कुंजी / मूल्य मॉडल |
---|---|---|
टेबल | बाल्टी | कक्षा या क्लस्टर |
पंक्ति | कुंजी / मूल्य जोड़ी | डाक्यूमेंट |
स्तंभ | उपलब्ध नहीं है | दस्तावेज़ फ़ील्ड या वर्टेक्स / एज प्रॉपर्टी |
संबंध | उपलब्ध नहीं है | संपर्क |
ऑब्जेक्ट मॉडल
यह मॉडल ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग और समर्थन द्वारा विरासत में मिला है Inheritance प्रकारों के बीच (उप-प्रकार सुपर-प्रकार का विस्तार करता है), Polymorphism जब आप एक बेस क्लास और देखें Direct binding से / प्रोग्रामिंग भाषाओं में उपयोग की जाने वाली वस्तुओं के लिए।
निम्न तालिका संबंधपरक मॉडल, ऑब्जेक्ट मॉडल और ओरिएंटीडी ऑब्जेक्ट मॉडल के बीच तुलना को दर्शाती है।
संबंधपरक मॉडल | ऑब्जेक्ट मॉडल | ओरिएंटबीडी ऑब्जेक्ट मॉडल |
---|---|---|
टेबल | कक्षा | कक्षा या क्लस्टर |
पंक्ति | वस्तु | दस्तावेज़ या वर्टेक्स |
स्तंभ | वस्तु संपत्ति | दस्तावेज़ फ़ील्ड या वर्टेक्स / एज प्रॉपर्टी |
संबंध | सूचक | संपर्क |
विस्तार से आगे बढ़ने से पहले, ओरिएंटडीबी से जुड़ी बुनियादी शब्दावली जानना बेहतर है। निम्नलिखित कुछ महत्वपूर्ण शब्दावली हैं।
अभिलेख
सबसे छोटी इकाई जिसे आप डेटाबेस में लोड और स्टोर कर सकते हैं। अभिलेखों को चार प्रकारों में संग्रहित किया जा सकता है।
- Document
- रिकॉर्ड बाइट्स
- Vertex
- Edge
रिकॉर्ड आईडी
जब OrientDB एक रिकॉर्ड बनाता है, डेटाबेस सर्वर स्वचालित रूप से रिकॉर्ड के लिए एक इकाई पहचानकर्ता प्रदान करता है, जिसे RecordID (RID) कहा जाता है। RID # <क्लस्टर>: <स्थिति> जैसा दिखता है। <क्लस्टर> का अर्थ है क्लस्टर पहचान संख्या और <स्थिति> का अर्थ है क्लस्टर में रिकॉर्ड की पूर्ण स्थिति।
दस्तावेज़
दस्तावेज़ ओरिएंटडीबी में उपलब्ध सबसे लचीला रिकॉर्ड प्रकार है। दस्तावेज़ों को धीरे से टाइप किया जाता है और स्कीमा वर्गों द्वारा परिभाषित बाधा के साथ परिभाषित किया जाता है, लेकिन आप दस्तावेज़ को बिना किसी स्कीमा के भी सम्मिलित कर सकते हैं, अर्थात यह स्कीमा-कम मोड का भी समर्थन करता है।
JSON प्रारूप में दस्तावेज़ों को आसानी से निर्यात और आयात द्वारा नियंत्रित किया जा सकता है। उदाहरण के लिए, निम्नलिखित JSON नमूना दस्तावेज़ पर एक नज़र डालें। यह दस्तावेज़ के विवरण को परिभाषित करता है।
{
"id" : "1201",
"name" : "Jay",
"job" : "Developer",
"creations" : [
{
"name" : "Amiga",
"company" : "Commodore Inc."
},
{
"name" : "Amiga 500",
"company" : "Commodore Inc."
}
]
}
RecordBytes
रिकॉर्ड प्रकार RDBMS में BLOB प्रकार के समान है। OrientDB बाइनरी डेटा के साथ दस्तावेज़ प्रकार को लोड और स्टोर कर सकता है।
शिखर
OrientDB डेटाबेस न केवल एक दस्तावेज़ डेटाबेस है, बल्कि एक ग्राफ़ डेटाबेस भी है। वर्टेक्स और एज जैसी नई अवधारणाओं का उपयोग ग्राफ के रूप में डेटा को स्टोर करने के लिए किया जाता है। ग्राफ डेटाबेस में, डेटा की सबसे बुनियादी इकाई नोड है, जिसे ओरिएंटबीडी में एक शीर्ष कहा जाता है। डेटाबेस के लिए वर्टेक्स जानकारी संग्रहीत करता है।
एज
एक अलग रिकॉर्ड प्रकार है जिसे एज कहा जाता है जो एक शीर्ष को दूसरे से जोड़ता है। किनारे द्विदिश हैं और केवल दो कोने जोड़ सकते हैं। ओरिएंटडीबी में दो प्रकार के किनारे हैं, एक नियमित है और दूसरा हल्का है।
कक्षा
वर्ग एक प्रकार का डेटा मॉडल है और ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग प्रतिमान से तैयार की गई अवधारणा है। पारंपरिक दस्तावेज़ डेटाबेस मॉडल के आधार पर, डेटा संग्रह के रूप में संग्रहीत किया जाता है, जबकि रिलेशनल डेटाबेस मॉडल डेटा तालिकाओं में संग्रहीत किया जाता है। OrientDB OPPS प्रतिमान के साथ दस्तावेज़ API का अनुसरण करता है। एक अवधारणा के रूप में, ओरिएंटडीबी में कक्षा का संबंधपरक डेटाबेस में तालिका के साथ निकटतम संबंध है, लेकिन (तालिकाओं के विपरीत) कक्षाएं स्कीमा-कम, स्कीमा-पूर्ण या मिश्रित हो सकती हैं। कक्षाएं कक्षाओं के पेड़ बनाने, अन्य वर्गों से विरासत में मिल सकती हैं। प्रत्येक वर्ग का अपना क्लस्टर या क्लस्टर होता है, (डिफ़ॉल्ट रूप से, यदि कोई भी परिभाषित नहीं है)।
समूह
क्लस्टर एक महत्वपूर्ण अवधारणा है जिसका उपयोग रिकॉर्ड, दस्तावेज़ या कोने को संग्रहीत करने के लिए किया जाता है। सरल शब्दों में, क्लस्टर एक ऐसी जगह है जहां रिकॉर्ड का एक समूह संग्रहीत किया जाता है। डिफ़ॉल्ट रूप से, OrientDB प्रति वर्ग एक क्लस्टर बनाएगा। एक वर्ग के सभी अभिलेखों को एक ही क्लस्टर में संग्रहीत किया जाता है जिसमें कक्षा के समान नाम होता है। आप एक डेटाबेस में 32,767 (2 ^ 15-1) क्लस्टर बना सकते हैं।
क्रिएट क्लास एक कमांड है जिसका उपयोग विशिष्ट नाम के साथ एक क्लस्टर बनाने के लिए किया जाता है। एक बार क्लस्टर बनने के बाद आप किसी भी डेटा मॉडल के निर्माण के दौरान नाम निर्दिष्ट करके रिकॉर्ड को बचाने के लिए क्लस्टर का उपयोग कर सकते हैं।
रिश्तों
ओरिएंटबीडी दो प्रकार के संबंधों का समर्थन करता है: संदर्भित और एम्बेडेड। Referenced relationships इसका मतलब है कि यह रिश्तों की लक्षित वस्तुओं के लिए सीधा लिंक संग्रहीत करता है। Embedded relationshipsइसका मतलब है कि यह रिकॉर्ड के भीतर संबंध को संग्रहीत करता है जो इसे एम्बेड करता है। यह संबंध संदर्भ संबंध से अधिक मजबूत है।
डेटाबेस
डेटाबेस वास्तविक भंडारण का उपयोग करने के लिए एक इंटरफ़ेस है। आईटी प्रश्नों, स्कीमा, मेटाडेटा, सूचकांकों, आदि जैसी उच्च-स्तरीय अवधारणाओं को समझता है। OrientDB भी कई डेटाबेस प्रकार प्रदान करता है। इन प्रकारों के बारे में अधिक जानकारी के लिए, डेटाबेस प्रकार देखें।