ArangoDB - डेटा मॉडल और मॉडलिंग
इस अध्याय में, हम निम्नलिखित विषयों पर ध्यान केंद्रित करेंगे -
- डेटाबेस इंटरेक्शन
- डेटा मॉडल
- डेटा की पुनःप्राप्ति
ArangoDB दस्तावेज़ आधारित डेटा मॉडल के साथ-साथ ग्राफ़ आधारित डेटा मॉडल का समर्थन करता है। हमें पहले दस्तावेज़ आधारित डेटा मॉडल का वर्णन करें।
ArangoDB के दस्तावेज़ बारीकी से JSON प्रारूप से मिलते जुलते हैं। शून्य या अधिक विशेषताएँ एक दस्तावेज़ में निहित हैं, और प्रत्येक विशेषता के साथ एक मूल्य जुड़ा हुआ है। एक मान या तो परमाणु प्रकार का होता है, जैसे संख्या, बूलियन या नल, शाब्दिक स्ट्रिंग, या एक यौगिक डेटा प्रकार, जैसे एम्बेडेड दस्तावेज़ / ऑब्जेक्ट या एक सरणी। सरणी या उप-ऑब्जेक्ट में इन डेटा प्रकार शामिल हो सकते हैं, जिसका अर्थ है कि एक एकल दस्तावेज़ गैर-तुच्छ डेटा संरचनाओं का प्रतिनिधित्व कर सकता है।
आगे पदानुक्रम में, दस्तावेजों को संग्रह में व्यवस्थित किया जाता है, जिसमें कोई दस्तावेज़ नहीं हो सकता है (सिद्धांत में) या एक से अधिक दस्तावेज़। कोई दस्तावेज़ों को पंक्तियों और संग्रहों की तुलना तालिकाओं से कर सकता है (यहाँ तालिकाओं और पंक्तियों का संबंध रिलेशनल डेटाबेस मैनेजमेंट सिस्टम - RDBMS से है)।
लेकिन, RDBMS में, इन परिभाषाओं को स्कीमा कहते हुए, स्तंभों को परिभाषित करना एक तालिका में अभिलेखों को संग्रहीत करने के लिए एक शर्त है। हालाँकि, एक उपन्यास विशेषता के रूप में, अरंगबोबे स्कीमा-कम है - यह निर्दिष्ट करने का कोई प्राथमिक कारण नहीं है कि दस्तावेज़ में क्या विशेषताएँ होंगी।
और RDBMS के विपरीत, प्रत्येक दस्तावेज़ को दूसरे दस्तावेज़ से पूरी तरह से अलग तरीके से संरचित किया जा सकता है। इन दस्तावेजों को एक एकल संग्रह में एक साथ बचाया जा सकता है। व्यावहारिक रूप से, संग्रह में दस्तावेजों के बीच आम विशेषताएं मौजूद हो सकती हैं, हालांकि डेटाबेस सिस्टम, यानी, अरेंजबीडीबी खुद को एक विशेष डेटा संरचना से नहीं बांधता है।
अब हम ArangoDB को समझने की कोशिश करेंगे [graph data model], जिसमें दो प्रकार के संग्रह की आवश्यकता होती है - पहला है दस्तावेज़ संग्रह (समूह-सिद्धांत भाषा में शीर्षकों के संग्रह के रूप में जाना जाता है), दूसरा किनारा संग्रह है। इन दो प्रकारों के बीच एक सूक्ष्म अंतर है। एज संग्रह भी दस्तावेजों को संग्रहीत करते हैं, लेकिन वे दो अद्वितीय विशेषताओं को शामिल करके विशेषता हैं,_from तथा _toदस्तावेजों के बीच संबंध बनाने के लिए। व्यवहार में, एक दस्तावेज़ (पढ़ा हुआ किनारा) दो दस्तावेजों को जोड़ता है (लंबवत पढ़ें), दोनों को उनके संबंधित संग्रह में संग्रहीत किया जाता है। यह आर्किटेक्चर एक लेबल वाले, निर्देशित ग्राफ के ग्राफ-सिद्धांत की अवधारणा से लिया गया है, जिसमें उन किनारों को छोड़कर जो न केवल लेबल हो सकते हैं, बल्कि अपने आप में दस्तावेज़ की तरह एक संपूर्ण JSON हो सकते हैं।
ताजा आंकड़ों की गणना करने के लिए, दस्तावेजों को हटा दें या उनमें हेरफेर करें, प्रश्नों का उपयोग किया जाता है, जो दिए गए मानदंडों के अनुसार दस्तावेजों का चयन या फ़िल्टर करते हैं। या तो "उदाहरण क्वेरी" के रूप में सरल या "जॉइन" के रूप में जटिल होने के नाते, प्रश्न AQL - ArangoDB क्वेरी भाषा में कोडित हैं।