DocumentDB SQL - Operator

Operator adalah kata atau karakter khusus yang digunakan terutama dalam klausa SQL WHERE untuk melakukan operasi, seperti perbandingan dan operasi aritmatika. DocumentDB SQL juga mendukung berbagai ekspresi skalar. Yang paling umum digunakan adalahbinary and unary expressions.

Operator SQL berikut saat ini didukung dan dapat digunakan dalam kueri.

Operator Perbandingan SQL

Berikut ini adalah daftar semua operator perbandingan yang tersedia dalam tata bahasa SQL DocumentDB.

S.No. Operator & Deskripsi
1

=

Memeriksa apakah nilai dari dua operan sama atau tidak. Jika ya, maka kondisinya menjadi benar.

2

!=

Memeriksa apakah nilai dari dua operan sama atau tidak. Jika nilai tidak sama maka kondisi menjadi benar.

3

<>

Memeriksa apakah nilai dari dua operan sama atau tidak. Jika nilai tidak sama maka kondisi menjadi benar.

4

>

Memeriksa apakah nilai operan kiri lebih besar dari nilai operan kanan. Jika ya, maka kondisinya menjadi benar.

5

<

Memeriksa apakah nilai operan kiri kurang dari nilai operan kanan. Jika ya, maka kondisinya menjadi benar.

6

>=

Memeriksa apakah nilai operan kiri lebih besar dari atau sama dengan nilai operan kanan. Jika ya, maka kondisinya menjadi benar.

7

<=

Memeriksa apakah nilai operan kiri kurang dari atau sama dengan nilai operan kanan. Jika ya, maka kondisinya menjadi benar.

Operator Logika SQL

Berikut adalah daftar semua operator logika yang tersedia dalam tata bahasa SQL DocumentDB.

S.No. Operator & Deskripsi
1

AND

Operator AND memungkinkan adanya beberapa kondisi dalam klausa WHERE pernyataan SQL.

2

BETWEEN

Operator BETWEEN digunakan untuk mencari nilai yang berada di dalam satu set nilai, dengan mempertimbangkan nilai minimum dan nilai maksimum.

3

IN

Operator IN digunakan untuk membandingkan nilai dengan daftar nilai literal yang telah ditentukan.

4

OR

Operator OR digunakan untuk menggabungkan beberapa kondisi dalam klausa WHERE pernyataan SQL.

5

NOT

Operator NOT membalikkan arti dari operator logika yang digunakannya. Misalnya TIDAK ADA, TIDAK ANTARA, TIDAK DI, dll. Ini adalah operator negate.

Operator Aritmatika SQL

Berikut ini adalah daftar semua operator aritmatika yang tersedia dalam tata bahasa SQL DocumentDB.

S.No. Operator & Deskripsi
1

+

Addition - Menambahkan nilai di kedua sisi operator.

2

-

Subtraction - Mengurangi operan tangan kanan dari operan tangan kiri.

3

*

Multiplication - Mengalikan nilai di kedua sisi operator.

4

/

Division - Membagi operan tangan kiri dengan operan tangan kanan.

5

%

Modulus - Membagi operan tangan kiri dengan operan tangan kanan dan mengembalikan sisanya.

Kami akan mempertimbangkan dokumen yang sama dalam contoh ini juga. Berikut ini adalahAndersenFamily dokumen.

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

Berikut ini adalah SmithFamily dokumen.

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

Berikut ini adalah WakefieldFamily dokumen.

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

Mari kita lihat contoh sederhana di mana operator perbandingan digunakan dalam klausa WHERE.

Dalam kueri ini, di klausa WHERE, kondisi (WHERE f.id = "WakefieldFamily") ditentukan, dan ini akan mengambil dokumen yang idnya sama dengan WakefieldFamily.

SELECT * 
FROM f  
WHERE f.id = "WakefieldFamily"

Ketika kueri di atas dijalankan, itu akan mengembalikan dokumen JSON lengkap untuk WakefieldFamily seperti yang ditunjukkan pada output berikut.

[ 
   { 
      "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/" 
   } 
]

Mari kita lihat contoh lain di mana kueri akan mengambil data anak yang nilainya lebih dari 5.

SELECT * 
FROM Families.children[0] c 
WHERE (c.grade > 5)

Ketika query di atas dijalankan, sub dokumen berikut akan diambil seperti yang ditunjukkan pada output.

[
   {
      "familyName": "Merriam", 
      "givenName": "Jesse", 
      "gender": "female", 
      "grade": 6, 
		
      "pets": [
         { 
            "givenName": "Charlie Brown", 
            "type": "Dog" 
         }, 
			
         { 
            "givenName": "Tiger", 
            "type": "Cat" 
         }, 
			
         { 
            "givenName": "Princess", 
            "type": "Cat" 
         } 
      ] 
   } 
]