Banco de Dados de Documentos - Tipos de Dados
JSON ou JavaScript Object Notation é um padrão aberto baseado em texto leve projetado para intercâmbio de dados legível por humanos e também fácil para máquinas analisar e gerar. JSON está no centro do DocumentDB. Transmitimos JSON pela rede, armazenamos JSON como JSON e indexamos a árvore JSON, permitindo consultas em todo o documento JSON.
O formato JSON suporta os seguintes tipos de dados -
S.No. | Tipo e descrição |
---|---|
1 | Number Formato de ponto flutuante de precisão dupla em JavaScript |
2 | String Unicode entre aspas duplas com escape de barra invertida |
3 | Boolean Verdadeiro ou falso |
4 | Array Uma sequência ordenada de valores |
5 | Value Pode ser uma string, um número, verdadeiro ou falso, nulo, etc. |
6 | Object Uma coleção não ordenada de pares chave: valor |
7 | Whitespace Pode ser usado entre qualquer par de tokens |
8 | Null Vazio |
Vamos dar uma olhada em um exemplo simples do tipo DateTime. Adicione a data de nascimento à classe do cliente.
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; }
}
Podemos armazenar, recuperar e consultar usando DateTime conforme mostrado no código a seguir.
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();
}
Quando o código acima for compilado e executado, e o documento for criado, você verá que a data de nascimento foi adicionada agora.
**** 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