DocumentDB SQL - कीवर्ड के बीच
BETWEEN कीवर्ड का उपयोग SQL में मानों की श्रेणी के विरुद्ध प्रश्न व्यक्त करने के लिए किया जाता है। BETWEEN का उपयोग स्ट्रिंग्स या संख्याओं के खिलाफ किया जा सकता है। DocumentDB और ANSI SQL में BETWEEN का उपयोग करने के बीच मुख्य अंतर यह है कि आप मिश्रित प्रकारों के गुणों के खिलाफ रेंज क्वेरी व्यक्त कर सकते हैं।
उदाहरण के लिए, कुछ दस्तावेज़ों में यह संभव है कि आपके पास एक संख्या के रूप में "ग्रेड" हो सकता है और अन्य दस्तावेजों में यह तार हो सकता है। इन मामलों में, दो अलग-अलग प्रकार के परिणामों के बीच तुलना "अपरिभाषित" है, और दस्तावेज़ को छोड़ दिया जाएगा।
आइए पिछले उदाहरण से तीन दस्तावेजों पर विचार करें। निम्नलिखित हैAndersenFamily दस्तावेज़।
{
"id": "AndersenFamily",
"lastName": "Andersen",
"parents": [
{ "firstName": "Thomas", "relationship": "father" },
{ "firstName": "Mary Kay", "relationship": "mother" }
],
"children": [
{
"firstName": "Henriette Thaulow",
"gender": "female",
"grade": 5,
"pets": [ { "givenName": "Fluffy", "type": "Rabbit" } ]
}
],
"location": { "state": "WA", "county": "King", "city": "Seattle" },
"isRegistered": true
}
निम्नलिखित है SmithFamily दस्तावेज़।
{
"id": "SmithFamily",
"parents": [
{ "familyName": "Smith", "givenName": "James" },
{ "familyName": "Curtis", "givenName": "Helen" }
],
"children": [
{
"givenName": "Michelle",
"gender": "female",
"grade": 1
},
{
"givenName": "John",
"gender": "male",
"grade": 7,
"pets": [
{ "givenName": "Tweetie", "type": "Bird" }
]
}
],
"location": {
"state": "NY",
"county": "Queens",
"city": "Forest Hills"
},
"isRegistered": true
}
निम्नलिखित है WakefieldFamily दस्तावेज़।
{
"id": "WakefieldFamily",
"parents": [
{ "familyName": "Wakefield", "givenName": "Robin" },
{ "familyName": "Miller", "givenName": "Ben" }
],
"children": [
{
"familyName": "Merriam",
"givenName": "Jesse",
"gender": "female",
"grade": 6,
"pets": [
{ "givenName": "Charlie Brown", "type": "Dog" },
{ "givenName": "Tiger", "type": "Cat" },
{ "givenName": "Princess", "type": "Cat" }
]
},
{
"familyName": "Miller",
"givenName": "Lisa",
"gender": "female",
"grade": 3,
"pets": [
{ "givenName": "Jake", "type": "Snake" }
]
}
],
"location": { "state": "NY", "county": "Manhattan", "city": "NY" },
"isRegistered": false
}
आइए एक उदाहरण देखें, जहां क्वेरी सभी परिवार के दस्तावेजों को लौटाती है जिसमें पहले बच्चे का ग्रेड 1-5 (दोनों समावेशी) के बीच होता है।
निम्नलिखित वह क्वेरी है जिसमें BETWEEN कीवर्ड का उपयोग किया जाता है और फिर AND तार्किक ऑपरेटर।
SELECT *
FROM Families.children[0] c
WHERE c.grade BETWEEN 1 AND 5
जब उपरोक्त क्वेरी निष्पादित होती है, तो यह निम्न आउटपुट का उत्पादन करती है।
[
{
"givenName": "Michelle",
"gender": "female",
"grade": 1
},
{
"firstName": "Henriette Thaulow",
"gender": "female",
"grade": 5,
"pets": [
{
"givenName": "Fluffy",
"type": "Rabbit"
}
]
}
]
पिछले उदाहरण की सीमा के बाहर ग्रेड प्रदर्शित करने के लिए, निम्न क्वेरी में दिखाए गए अनुसार NOT BETWEEN का उपयोग करें।
SELECT *
FROM Families.children[0] c
WHERE c.grade NOT BETWEEN 1 AND 5
जब इस क्वेरी को निष्पादित किया जाता है। यह निम्न आउटपुट का उत्पादन करता है।
[
{
"familyName": "Merriam",
"givenName": "Jesse",
"gender": "female",
"grade": 6,
"pets": [
{
"givenName": "Charlie Brown",
"type": "Dog"
},
{
"givenName": "Tiger",
"type": "Cat"
},
{
"givenName": "Princess",
"type": "Cat"
}
]
}
]