DocumentDB - Datentypen

JSON- oder JavaScript-Objektnotation ist ein leichter, textbasierter offener Standard, der für den lesbaren Datenaustausch entwickelt wurde und auch für Maschinen leicht zu analysieren und zu generieren ist. JSON ist das Herzstück von DocumentDB. Wir übertragen JSON über die Leitung, speichern JSON als JSON und indizieren den JSON-Baum, sodass Abfragen für das gesamte JSON-Dokument möglich sind.

Das JSON-Format unterstützt die folgenden Datentypen:

S.No. Typ & Beschreibung
1

Number

Gleitkommaformat mit doppelter Genauigkeit in JavaScript

2

String

Unicode in doppelten Anführungszeichen mit ausgeblendetem Backslash

3

Boolean

Richtig oder falsch

4

Array

Eine geordnete Folge von Werten

5

Value

Es kann eine Zeichenfolge, eine Zahl, wahr oder falsch, null usw. sein.

6

Object

Eine ungeordnete Sammlung von Schlüssel: Wert-Paaren

7

Whitespace

Es kann zwischen jedem Token-Paar verwendet werden

8

Null

Leer

Schauen wir uns ein einfaches Beispiel für einen DateTime-Typ an. Fügen Sie der Kundenklasse das Geburtsdatum hinzu.

public class Customer {
   [JsonProperty(PropertyName = "id")] 
   public string Id { get; set; }
	
   // Must be nullable, unless generating unique values for new customers on client  
   [JsonProperty(PropertyName = "name")] 
   public string Name { get; set; }  
	
   [JsonProperty(PropertyName = "address")] 
   public Address Address { get; set; }  
	
   [JsonProperty(PropertyName = "birthDate")] 
   public DateTime BirthDate { get; set; } 
}

Wir können mit DateTime speichern, abrufen und abfragen, wie im folgenden Code gezeigt.

private async static Task CreateDocuments(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** Create Documents ****"); 
   Console.WriteLine();
	
   var document3Definition = new Customer { 
      Id = "1001", 
      Name = "Luke Andrew", 
		
      Address = new Address { 
         AddressType = "Main Office", 
         AddressLine1 = "123 Main Street", 
         Location = new Location {
            City = "Brooklyn",
            StateProvinceName = "New York" 
         }, 
         PostalCode = "11229",
         CountryRegionName = "United States" 
      },
		
      BirthDate = DateTime.Parse(DateTime.Today.ToString()), 
   };
	
   Document document3 = await CreateDocument(client, document3Definition); 
   Console.WriteLine("Created document {0} from typed object", document3.Id); 
   Console.WriteLine(); 
}

Wenn der obige Code kompiliert und ausgeführt wird und das Dokument erstellt wird, wird das Geburtsdatum jetzt hinzugefügt.

**** Create Documents ****  
Created new document: 1001 
{ 
   "id": "1001", 
   "name": "Luke Andrew", 
   "address": { 
      "addressType": "Main Office", 
      "addressLine1": "123 Main Street", 
      "location": { 
         "city": "Brooklyn", 
         "stateProvinceName": "New York" 
      }, 
      "postalCode": "11229", 
      "countryRegionName": "United States" 
   }, 
   "birthDate": "2015-12-14T00:00:00", 
   "_rid": "Ic8LAMEUVgAKAAAAAAAAAA==", 
   "_ts": 1450113676, 
   "_self": "dbs/Ic8LAA==/colls/Ic8LAMEUVgA=/docs/Ic8LAMEUVgAKAAAAAAAAAA==/", 
   "_etag": "\"00002d00-0000-0000-0000-566efa8c0000\"", 
   "_attachments": "attachments/" 
} 
Created document 1001 from typed object