DocumentDB SQL - Wert Schlüsselwort

Wenn Sie wissen, dass Sie nur einen einzigen Wert zurückgeben, kann das Schlüsselwort VALUE dazu beitragen, eine schlankere Ergebnismenge zu erzielen, indem der Aufwand für die Erstellung eines vollständigen Objekts vermieden wird. Das Schlüsselwort VALUE bietet eine Möglichkeit, den JSON-Wert zurückzugeben.

Schauen wir uns ein einfaches Beispiel an.

Es folgt die Abfrage mit dem Schlüsselwort VALUE.

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

Wenn diese Abfrage ausgeführt wird, wird der Skalar "Hallo Welt, dies ist DocumentDB SQL Tutorial" zurückgegeben.

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

In einem anderen Beispiel betrachten wir die drei Dokumente aus den vorherigen Beispielen.

Es folgt die AndersenFamily Dokument.

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

Es folgt die SmithFamily Dokument.

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

Es folgt die WakefieldFamily Dokument.

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

Es folgt die Abfrage.

SELECT VALUE f.location 
FROM Families f

Wenn diese Abfrage ausgeführt wird, gibt sie die Adresse ohne Standortbezeichnung zurück.

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

Wenn wir jetzt dieselbe Abfrage ohne VALUE-Schlüsselwort angeben, wird die Adresse mit der Standortbezeichnung zurückgegeben. Es folgt die Abfrage.

SELECT f.location 
FROM Families f

Wenn diese Abfrage ausgeführt wird, wird die folgende Ausgabe erzeugt.

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