DocumentDB SQL-연산자

연산자는 비교 및 ​​산술 연산과 같은 연산을 수행하기 위해 주로 SQL WHERE 절에서 사용되는 예약어 또는 문자입니다. DocumentDB SQL은 다양한 스칼라 표현식도 지원합니다. 가장 일반적으로 사용되는 것은binary and unary expressions.

다음 SQL 연산자가 현재 지원되며 쿼리에 사용할 수 있습니다.

SQL 비교 연산자

다음은 DocumentDB SQL 문법에서 사용할 수있는 모든 비교 연산자 목록입니다.

S. 아니. 연산자 및 설명
1

=

두 피연산자의 값이 같은지 확인합니다. 그렇다면 조건이 참이됩니다.

2

!=

두 피연산자의 값이 같은지 확인합니다. 값이 같지 않으면 조건이 참이됩니다.

<>

두 피연산자의 값이 같은지 확인합니다. 값이 같지 않으면 조건이 참이됩니다.

4

>

왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 큰지 확인합니다. 그렇다면 조건이 참이됩니다.

5

<

왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작은 지 확인합니다. 그렇다면 조건이 참이됩니다.

6

>=

왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 크거나 같은지 확인합니다. 그렇다면 조건이 참이됩니다.

7

<=

왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작거나 같은지 확인합니다. 그렇다면 조건이 참이됩니다.

SQL 논리 연산자

다음은 DocumentDB SQL 문법에서 사용할 수있는 모든 논리 연산자 목록입니다.

S. 아니. 연산자 및 설명
1

AND

AND 연산자를 사용하면 SQL 문의 WHERE 절에 여러 조건이있을 수 있습니다.

2

BETWEEN

BETWEEN 연산자는 최소값과 최대 값이 주어진 경우 값 집합 내에있는 값을 검색하는 데 사용됩니다.

IN

IN 연산자는 값을 지정된 리터럴 값 목록과 비교하는 데 사용됩니다.

4

OR

OR 연산자는 SQL 문의 WHERE 절에서 여러 조건을 결합하는 데 사용됩니다.

5

NOT

NOT 연산자는 사용되는 논리 연산자의 의미를 반대로합니다. 예를 들어, NOT EXISTS, NOT BETWEEN, NOT IN 등입니다. 이것은 부정 연산자입니다.

SQL 산술 연산자

다음은 DocumentDB SQL 문법에서 사용할 수있는 모든 산술 연산자 목록입니다.

S. 아니. 연산자 및 설명
1

+

Addition − 연산자의 양쪽에 값을 추가합니다.

2

-

Subtraction − 왼손 피연산자에서 오른손 피연산자를 뺍니다.

*

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") 조건이 지정되고 ID가 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" 
         } 
      ] 
   } 
]