DocumentDB SQL - स्केलर एक्सप्रेशन

DocumentDB SQL में, SELECT क्लॉज भी स्केलर एक्सप्रेशन जैसे कॉन्स्टेंट, अरिथमेटिक एक्सप्रेशंस, लॉजिकल एक्सप्रेशंस आदि को सपोर्ट करता है। आमतौर पर, स्केलर क्वेश्चन शायद ही कभी यूज किए जाते हैं, क्योंकि वे कलेक्शन में डॉक्युमेंट्स को क्वेरी नहीं करते हैं, वे सिर्फ एक्सप्रेशन का मूल्यांकन करते हैं। लेकिन यह अभी भी मूल बातें जानने के लिए स्केलर अभिव्यक्ति प्रश्नों का उपयोग करने में मददगार है, एक क्वेरी में अभिव्यक्ति और JSON का उपयोग कैसे करें, और ये अवधारणाएं उन वास्तविक प्रश्नों पर सीधे लागू होती हैं जिन्हें आप एक संग्रह में दस्तावेजों के खिलाफ चला रहे हैं।

आइए एक उदाहरण देखें जिसमें कई स्केलर प्रश्न होते हैं।

क्वेरी एक्सप्लोरर में, निष्पादित होने वाले पाठ का चयन करें और 'रन' पर क्लिक करें। चलो इसे पहले चलाएं।

SELECT "Hello"

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

[ 
   { 
      "$1": "Hello" 
   } 
]

यह आउटपुट थोड़ा भ्रामक लग सकता है, इसलिए इसे तोड़ दें।

  • सबसे पहले, जैसा कि हमने पिछले डेमो में देखा, क्वेरी परिणाम हमेशा वर्ग कोष्ठक में समाहित होते हैं क्योंकि उन्हें JSON सरणी के रूप में लौटाया जाता है, यहां तक ​​कि स्केलर एक्सप्रेशन प्रश्नों से भी ऐसा होता है कि केवल एक ही दस्तावेज़ लौटाता है।

  • हमारे पास इसमें एक दस्तावेज़ के साथ एक सरणी है, और उस दस्तावेज़ में SELECT स्टेटमेंट में एकल अभिव्यक्ति के लिए एक एकल गुण है।

  • SELECT स्टेटमेंट इस प्रॉपर्टी के लिए कोई नाम प्रदान नहीं करता है, इस प्रकार डॉक्यूमेंटीडी ऑटो $ 1 का उपयोग करके उत्पन्न करता है।

  • यह आमतौर पर वह नहीं है जो हम चाहते हैं, यही कारण है कि हम क्वेरी में अभिव्यक्ति को उपनाम करने के लिए एएस का उपयोग कर सकते हैं, जो उत्पन्न दस्तावेज में संपत्ति का नाम सेट करता है जिस तरह से आप इसे पसंद करते हैं, शब्द, इस उदाहरण में।

SELECT "Hello" AS word

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

[ 
   { 
      "word": "Hello" 
   } 
]

इसी तरह, निम्नलिखित एक और सरल प्रश्न है।

SELECT ((2 + 11 % 7)-2)/3

क्वेरी निम्न आउटपुट को पुनः प्राप्त करती है।

[ 
   { 
      "$1": 1.3333333333333333 
   } 
]

आइए नेस्टेड सरणियों और एम्बेडेड ऑब्जेक्ट्स को आकार देने के एक और उदाहरण पर एक नज़र डालें।

SELECT 
   { 
      "words1": 
         ["Hello", "World"], 
      "words2": 
         ["How", "Are", "You?"] 
   } AS allWords

जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।

[ 
   { 
      "allWords": { 
         "words1": [ 
            "Hello", 
            "World" 
         ],
			
         "words2": [ 
            "How", 
            "Are", 
            "You?" 
         ] 
      } 
   } 
]