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?"
]
}
}
]