DocumentDB SQL - ऑपरेटर्स
एक ऑपरेटर एक आरक्षित शब्द या एक चरित्र है जो मुख्य रूप से SQL WHERE क्लॉज में ऑपरेशन (एस), जैसे कि तुलना और अंकगणितीय संचालन करने के लिए उपयोग किया जाता है। DocumentDB SQL भी विभिन्न प्रकार के अदिश भावों का समर्थन करता है। सबसे अधिक उपयोग किया जाता हैbinary and unary expressions।
निम्न SQL ऑपरेटर वर्तमान में समर्थित हैं और क्वेरीज़ में उपयोग किए जा सकते हैं।
एसक्यूएल तुलना ऑपरेटर
डॉक्यूमेंटडीबी एसक्यूएल व्याकरण में उपलब्ध सभी तुलना ऑपरेटरों की सूची निम्नलिखित है।
क्र.सं. | ऑपरेटर और विवरण |
---|---|
1 | = जाँच करता है कि दो ऑपरेंड का मान बराबर है या नहीं। यदि हाँ, तो स्थिति सच हो जाती है। |
2 | != जाँच करता है कि दो ऑपरेंड का मान बराबर है या नहीं। यदि मूल्य समान नहीं हैं तो स्थिति सत्य हो जाती है। |
3 | <> जाँच करता है कि दो ऑपरेंड का मान बराबर है या नहीं। यदि मूल्य समान नहीं हैं तो स्थिति सत्य हो जाती है। |
4 | > जाँचता है कि क्या बाएं ऑपरेंड का मान सही ऑपरेंड के मूल्य से अधिक है। यदि हाँ, तो स्थिति सच हो जाती है। |
5 | < जांचता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से कम है। यदि हाँ, तो स्थिति सच हो जाती है। |
6 | >= यह जाँचता है कि बाएँ ऑपरेंड का मान सही ऑपरेंड के मान से अधिक या उसके बराबर है या नहीं। यदि हाँ, तो स्थिति सच हो जाती है। |
7 | <= यह जाँचता है कि बाएँ ऑपरेंड का मान सही ऑपरेंड के मान से कम या उसके बराबर है या नहीं। यदि हाँ, तो स्थिति सच हो जाती है। |
SQL लॉजिकल ऑपरेटर्स
निम्नलिखित सभी तार्किक ऑपरेटरों की एक सूची है डॉक्यूमेंटडीबी एसक्यूएल व्याकरण में उपलब्ध है।
क्र.सं. | ऑपरेटर और विवरण |
---|---|
1 | AND AND ऑपरेटर SQL स्टेटमेंट के WHERE क्लॉज में कई स्थितियों के अस्तित्व की अनुमति देता है। |
2 | BETWEEN BETWEEN ऑपरेटर का उपयोग उन मानों की खोज के लिए किया जाता है जो मानों के एक सेट के भीतर होते हैं, न्यूनतम मूल्य और अधिकतम मूल्य दिया जाता है। |
3 | IN IN ऑपरेटर का उपयोग उन मानों की सूची की मान की तुलना करने के लिए किया जाता है जिन्हें निर्दिष्ट किया गया है। |
4 | OR OR ऑपरेटर का उपयोग SQL स्टेटमेंट के WHERE क्लॉज में कई स्थितियों को संयोजित करने के लिए किया जाता है। |
5 | NOT NOT ऑपरेटर उस तार्किक ऑपरेटर के अर्थ को उलट देता है जिसके साथ इसका उपयोग किया जाता है। उदाहरण के लिए, EXISTS, NOT BETWEEN, NOT IN, आदि। यह एक नकारात्मक संचालक है। |
SQL अंकगणितीय ऑपरेटर्स
डॉक्यूमेंटडीबी SQL व्याकरण में उपलब्ध सभी अंकगणितीय ऑपरेटरों की सूची निम्नलिखित है।
क्र.सं. | ऑपरेटर और विवरण |
---|---|
1 | + Addition - ऑपरेटर के दोनों ओर मान जोड़ता है। |
2 | - Subtraction - बाएं हाथ के ऑपरेंड से दाहिने हाथ के ऑपरेंड को घटाएं। |
3 | * Multiplication - ऑपरेटर के दोनों ओर मूल्यों को गुणा करता है। |
4 | / Division - दाहिने हाथ के ऑपरेंड द्वारा बाएं हाथ के ऑपरेंड को विभाजित करता है। |
5 | % Modulus - बाएं हाथ के ऑपरेंड को दाहिने हाथ के ऑपरेंड से विभाजित करता है और शेष को वापस करता है। |
हम इस उदाहरण में समान दस्तावेजों पर भी विचार करेंगे। निम्नलिखित है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
}
आइए एक साधारण उदाहरण देखें जिसमें एक तुलना ऑपरेटर का उपयोग WHERE क्लॉज में किया गया है।
इस क्वेरी में, WHERE क्लॉज में, (WHERE f.id = "WakefieldFamily") स्थिति निर्दिष्ट है, और यह उस दस्तावेज़ को पुनः प्राप्त करेगा जिसकी आईडी WakefieldFamily के बराबर है।
SELECT *
FROM f
WHERE f.id = "WakefieldFamily"
जब उपरोक्त क्वेरी निष्पादित होती है, तो यह WakefieldFamily के लिए पूरा JSON दस्तावेज़ लौटाएगा जैसा कि निम्नलिखित आउटपुट में दिखाया गया है।
[
{
"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,
"_rid": "Ic8LAJFujgECAAAAAAAAAA==",
"_ts": 1450541623,
"_self": "dbs/Ic8LAA==/colls/Ic8LAJFujgE=/docs/Ic8LAJFujgECAAAAAAAAAA==/",
"_etag": "\"00000500-0000-0000-0000-567582370000\"",
"_attachments": "attachments/"
}
]
आइए एक और उदाहरण देखें जिसमें क्वेरी उन बच्चों के डेटा को पुनः प्राप्त करेगी जिनकी ग्रेड 5 से अधिक है।
SELECT *
FROM Families.children[0] c
WHERE (c.grade > 5)
जब उपरोक्त क्वेरी निष्पादित की जाती है, तो यह आउटपुट में दिखाए अनुसार निम्न उप दस्तावेज़ को पुनः प्राप्त करेगा।
[
{
"familyName": "Merriam",
"givenName": "Jesse",
"gender": "female",
"grade": 6,
"pets": [
{
"givenName": "Charlie Brown",
"type": "Dog"
},
{
"givenName": "Tiger",
"type": "Cat"
},
{
"givenName": "Princess",
"type": "Cat"
}
]
}
]