DocumentDB SQL - Değer Anahtar Kelimesi

Yalnızca tek bir değer döndürdüğünüzü bildiğinizde, VALUE anahtar sözcüğü, tam gelişmiş bir nesne oluşturmanın ek yükünden kaçınarak daha yalın bir sonuç kümesi oluşturmanıza yardımcı olabilir. VALUE anahtar sözcüğü, JSON değerini döndürmenin bir yolunu sağlar.

Basit bir örneğe bakalım.

VALUE anahtar kelimeli sorgu aşağıdadır.

SELECT VALUE "Hello World, this is DocumentDB SQL Tutorial"

Bu sorgu yürütüldüğünde, "Merhaba Dünya, bu DocumentDB SQL Eğitimi" skalerini döndürür.

[ 
   "Hello World, this is DocumentDB SQL Tutorial" 
]

Başka bir örnekte, önceki örneklerden üç belgeye bakalım.

Aşağıdaki AndersenFamily belge.

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

Aşağıdaki SmithFamily belge.

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

Aşağıdaki WakefieldFamily belge.

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

Sorgu aşağıdadır.

SELECT VALUE f.location 
FROM Families f

Bu sorgu yürütüldüğünde, adresi konum etiketi olmadan döndürür.

[ 
   { 
      "state": "NY", 
      "county": "Manhattan", 
      "city": "NY" 
   }, 
	
   { 
      "state": "NY", 
      "county": "Queens", 
      "city": "Forest Hills" 
   },
	
   { 
      "state": "WA", 
      "county": "King", 
      "city": "Seattle" 
   } 
]

Şimdi aynı sorguyu VALUE Anahtar Kelime olmadan belirtirsek, o zaman adres konum etiketli olarak dönecektir. Sorgu aşağıdadır.

SELECT f.location 
FROM Families f

Bu sorgu yürütüldüğünde aşağıdaki çıktıyı üretir.

[ 
   { 
      "location": { 
         "state": "NY", 
         "county": "Manhattan", 
         "city": "NY" 
      } 
   }, 
	
   { 
      "location": { 
         "state": "NY", 
         "county": "Queens", 
         "city": "Forest Hills" 
      } 
   },
	
   { 
      "location": { 
         "state": "WA", 
         "county": "King", 
         "city": "Seattle" 
      } 
   } 
]