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