DocumentDB SQL - ओवरव्यू
DocumentDB Microsoft का नवीनतम NoSQL दस्तावेज़ डेटाबेस प्लेटफ़ॉर्म है जो Azure पर चलता है। इस ट्यूटोरियल में, हम DocumentDB द्वारा समर्थित SQL के विशेष संस्करण का उपयोग करके दस्तावेज़ों को क्वेरी करने के बारे में सीखेंगे।
NoSQL दस्तावेज़ डेटाबेस
DocumentDB Microsoft का सबसे नया NoSQL डॉक्यूमेंट डेटाबेस है, हालाँकि, जब हम कहते हैं कि NoSQL डॉक्यूमेंट डेटाबेस, तो NoSQL से हमारा क्या तात्पर्य है, और डॉक्यूमेंट डेटाबेस?
SQL का मतलब स्ट्रक्चर्ड क्वेरी लैंग्वेज है जो रिलेशनल डेटाबेस की एक पारंपरिक क्वेरी लैंग्वेज है। SQL को अक्सर रिलेशनल डेटाबेस के साथ बराबर किया जाता है।
NoSQL डेटाबेस को एक गैर-रिलेशनल डेटाबेस के रूप में सोचना वास्तव में अधिक उपयोगी है, इसलिए NoSQL वास्तव में गैर-रिलेशनल है।
NoSQL डेटाबेस के विभिन्न प्रकार हैं जिनमें प्रमुख मूल्य भंडार शामिल हैं जैसे -
- एज़्योर टेबल स्टोरेज
- स्तंभ-आधारित स्टोर, जैसे कैसंड्रा
- ग्राफ़ डेटाबेस, NEO4 की तरह
- दस्तावेज़ डेटाबेस, जैसे MongoDB और Azure DocumentDB
SQL सिंटेक्स क्यों?
यह पहली बार में अजीब लग सकता है, लेकिन DocumentDB में जो एक NoSQL डेटाबेस है, हम SQL का उपयोग करके क्वेरी करते हैं। जैसा कि ऊपर उल्लेख किया गया है, यह JSON और जावास्क्रिप्ट शब्दार्थ में निहित SQL का एक विशेष संस्करण है।
SQL सिर्फ एक भाषा है, लेकिन यह एक बहुत लोकप्रिय भाषा है जो समृद्ध और अभिव्यंजक है। इस प्रकार, यह निश्चित रूप से एसक्यूएल की कुछ बोली का उपयोग करने के लिए एक अच्छा विचार की तरह लगता है, बल्कि प्रश्नों को व्यक्त करने का एक नया तरीका है, जिसे आपको सीखना होगा यदि आप अपने डेटाबेस से दस्तावेज़ प्राप्त करना चाहते हैं।
SQL रिलेशनल डेटाबेस के लिए डिज़ाइन किया गया है, और DocumentDB एक गैर-रिलेशनल दस्तावेज़ डेटाबेस है। DocumentDB टीम ने वास्तव में दस्तावेज़ डेटाबेस की गैर-संबंधपरक दुनिया के लिए SQL सिंटैक्स को अनुकूलित किया है, और इसका मतलब JSON और जावास्क्रिप्ट में SQL को रूट करके है।
भाषा अभी भी परिचित SQL के रूप में पढ़ती है, लेकिन शब्दार्थ सभी संबंधपरक तालिकाओं के बजाय स्कीमाफ्री JSON दस्तावेजों पर आधारित हैं। DocumentDB में, हम SQL डेटा प्रकारों के बजाय जावास्क्रिप्ट डेटा प्रकारों के साथ काम करेंगे। हम SELECT, FROM, WHERE, इत्यादि से परिचित होंगे, लेकिन जावास्क्रिप्ट प्रकारों के साथ, जो संख्या और तार तक सीमित हैं, ऑब्जेक्ट, सरणियाँ, बूलियन, और नल SQL डेटा प्रकारों की विस्तृत श्रृंखला से बहुत कम हैं।
इसी तरह, अभिव्यक्तियों को टी-एसक्यूएल के कुछ रूप के बजाय जावास्क्रिप्ट अभिव्यक्तियों के रूप में मूल्यांकन किया जाता है। उदाहरण के लिए, एक डेटा की दुनिया में, हम पंक्तियों और स्तंभों के साथ काम नहीं कर रहे हैं, लेकिन स्कीयर रहित दस्तावेज़ों में पदानुक्रमित संरचनाएं होती हैं जिनमें नेस्टेड एरे और ऑब्जेक्ट होते हैं।
SQL कैसे काम करता है?
DocumentDB टीम ने कई अभिनव तरीकों से इस सवाल का जवाब दिया है। उनमें से कुछ इस प्रकार सूचीबद्ध हैं -
पहले, यह मानकर कि आपने किसी प्रॉपर्टी में किसी प्रॉपर्टी को अपने आप इंडेक्स करने के लिए डिफॉल्ट बिहेवियर को नहीं बदला है, आप डॉक्युमेंटेशन नोटेशन का उपयोग किसी भी प्रॉपर्टी पर जाने के लिए कर सकते हैं, चाहे वह डॉक्यूमेंट में कितनी भी नेस्टेड क्यों न हो।
आप एक इंट्रा-डॉक्यूमेंट जॉइन भी कर सकते हैं जिसमें नेस्टेड ऐरे एलिमेंट्स अपने पेरेंट एलिमेंट के साथ डॉक्यूमेंट के भीतर जुड़ते हैं जिस तरह से रिलेटेड वर्ल्ड में दो टेबलों के बीच जॉइन होता है।
आपके क्वेरीज़ डेटाबेस से दस्तावेज़ों को वापस कर सकते हैं, जैसा कि आप कर सकते हैं, या आप जितने चाहें उतने कस्टम दस्तावेज़ JSON आकार पर आधारित कर सकते हैं या जितने दस्तावेज़ डेटा चाहते हैं।
DocumentDB में SQL सहित कई आम ऑपरेटरों का समर्थन करता है -
अंकगणित और बिटवाइज संचालन
और या तर्क
समानता और सीमा की तुलना
स्ट्रिंग संगति
क्वेरी भाषा बिल्ट-इन फ़ंक्शन के होस्ट का भी समर्थन करती है।