DocumentDB SQL - Tłumaczenie z Linq na SQL
W usłudze DocumentDB faktycznie używamy języka SQL do wykonywania zapytań dotyczących dokumentów. Jeśli zajmujemy się programowaniem .NET, istnieje również dostawca LINQ, którego można użyć i który może wygenerować odpowiedni kod SQL z zapytania LINQ.
Obsługiwane typy danych
W usłudze DocumentDB wszystkie typy pierwotne JSON są obsługiwane przez dostawcę LINQ dołączonego do zestawu SDK usługi DocumentDB .NET, które są następujące -
- Numeric
- Boolean
- String
- Null
Obsługiwane wyrażenie
Następujące wyrażenia skalarne są obsługiwane przez dostawcę LINQ dołączonego do zestawu DocumentDB .NET SDK.
Constant Values - Zawiera stałe wartości pierwotnych typów danych.
Property/Array Index Expressions - Wyrażenia odnoszą się do właściwości obiektu lub elementu tablicy.
Arithmetic Expressions - Zawiera typowe wyrażenia arytmetyczne dotyczące wartości liczbowych i logicznych.
String Comparison Expression - Obejmuje porównanie wartości ciągu z jakąś stałą wartością ciągu.
Object/Array Creation Expression- Zwraca obiekt typu wartości złożonej lub typu anonimowego albo tablicę takich obiektów. Te wartości mogą być zagnieżdżane.
Obsługiwane operatory LINQ
Oto lista obsługiwanych operatorów LINQ w dostawcy LINQ dołączonym do zestawu DocumentDB .NET SDK.
Select - Projekcje przekładają się na SQL SELECT, w tym konstrukcję obiektu.
Where- Filtry tłumaczą do SQL WHERE i obsługują tłumaczenie między &&, || i ! do operatorów SQL.
SelectMany- Umożliwia rozwijanie tablic do klauzuli SQL JOIN. Może służyć do łączenia w łańcuch / zagnieżdżania wyrażeń w celu filtrowania elementów tablicy.
OrderBy and OrderByDescending - Przekłada się na ORDER BY rosnąco / malejąco.
CompareTo- Przekłada się na porównania zakresów. Powszechnie używane dla ciągów, ponieważ nie są porównywalne w .NET.
Take - Tłumaczy na SQL TOP w celu ograniczenia wyników zapytania.
Math Functions - Obsługuje tłumaczenie z .NET's Abs, Acos, Asin, Atan, Ceiling, Cos, Exp, Floor, Log, Log10, Pow, Round, Sign, Sin, Sqrt, Tan, Truncate do równoważnych wbudowanych funkcji SQL.
String Functions - Obsługuje tłumaczenie z .NET's Concat, Contains, EndsWith, IndexOf, Count, ToLower, TrimStart, Replace, Reverse, TrimEnd, StartsWith, SubString, ToUpper na równoważne wbudowane funkcje SQL.
Array Functions - Obsługuje tłumaczenie z .NET's Concat, Contains i Count na równoważne wbudowane funkcje SQL.
Geospatial Extension Functions - Obsługuje tłumaczenie metod pośredniczących Distance, Within, IsValid i IsValidDetailed do równoważnych wbudowanych funkcji SQL.
User-Defined Extension Function - Obsługuje tłumaczenie z metody pośredniczącej UserDefinedFunctionProvider.Invoke na odpowiednią funkcję zdefiniowaną przez użytkownika.
Miscellaneous- Obsługuje tłumaczenie operatorów koalescencyjnych i warunkowych. Może przetłumaczyć Contains na String CONTAINS, ARRAY_CONTAINS lub SQL IN w zależności od kontekstu.
Spójrzmy na przykład, w którym będziemy używać .Net SDK. Poniżej znajdują się trzy dokumenty, które będziemy rozważać w tym przykładzie.
Nowy klient 1
{
"name": "New Customer 1",
"address": {
"addressType": "Main Office",
"addressLine1": "123 Main Street",
"location": {
"city": "Brooklyn",
"stateProvinceName": "New York"
},
"postalCode": "11229",
"countryRegionName": "United States"
},
}
Nowy klient 2
{
"name": "New Customer 2",
"address": {
"addressType": "Main Office",
"addressLine1": "678 Main Street",
"location": {
"city": "London",
"stateProvinceName": " London "
},
"postalCode": "11229",
"countryRegionName": "United Kingdom"
},
}
Nowy klient 3
{
"name": "New Customer 3",
"address": {
"addressType": "Main Office",
"addressLine1": "12 Main Street",
"location": {
"city": "Brooklyn",
"stateProvinceName": "New York"
},
"postalCode": "11229",
"countryRegionName": "United States"
},
}
Poniżej znajduje się kod, w którym wykonujemy zapytania przy użyciu LINQ. Zdefiniowaliśmy zapytanie LINQ wq, ale nie zostanie wykonany, dopóki nie uruchomimy na nim .ToList.
private static void QueryDocumentsWithLinq(DocumentClient client) {
Console.WriteLine();
Console.WriteLine("**** Query Documents (LINQ) ****");
Console.WriteLine();
Console.WriteLine("Quering for US customers (LINQ)");
var q =
from d in client.CreateDocumentQuery<Customer>(collection.DocumentsLink)
where d.Address.CountryRegionName == "United States"
select new {
Id = d.Id,
Name = d.Name,
City = d.Address.Location.City
};
var documents = q.ToList();
Console.WriteLine("Found {0} US customers", documents.Count);
foreach (var document in documents) {
var d = document as dynamic;
Console.WriteLine(" Id: {0}; Name: {1}; City: {2}", d.Id, d.Name, d.City);
}
Console.WriteLine();
}
Zestaw SDK przekonwertuje nasze zapytanie LINQ na składnię SQL dla DocumentDB, generując klauzulę SELECT i WHERE na podstawie naszej składni LINQ.
Nazwijmy powyższe zapytania z zadania CreateDocumentClient.
private static async Task CreateDocumentClient() {
// Create a new instance of the DocumentClient
using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
database = client.CreateDatabaseQuery("SELECT * FROM c WHERE c.id =
'myfirstdb'").AsEnumerable().First();
collection = client.CreateDocumentCollectionQuery(database.CollectionsLink,
"SELECT * FROM c WHERE c.id = 'MyCollection'").AsEnumerable().First();
QueryDocumentsWithLinq(client);
}
}
Kiedy powyższy kod jest wykonywany, generuje następujące dane wyjściowe.
**** Query Documents (LINQ) ****
Quering for US customers (LINQ)
Found 2 US customers
Id: 7e9ad4fa-c432-4d1a-b120-58fd7113609f; Name: New Customer 1; City: Brooklyn
Id: 34e9873a-94c8-4720-9146-d63fb7840fad; Name: New Customer 1; City: Brooklyn