DocumentDB - Begrenzung von Datensätzen
Microsoft hat kürzlich eine Reihe von Verbesserungen für die Abfrage von Azure DocumentDB hinzugefügt, z. B. das Schlüsselwort TOP für die SQL-Grammatik, mit dem Abfragen schneller ausgeführt werden und weniger Ressourcen verbrauchen, die Grenzwerte für Abfrageoperatoren erhöht und die Unterstützung für zusätzliche LINQ-Operatoren in hinzugefügt wurden das .NET SDK.
Schauen wir uns ein einfaches Beispiel an, in dem wir nur die ersten beiden Datensätze abrufen. Wenn Sie über mehrere Datensätze verfügen und nur einige davon abrufen möchten, können Sie das Schlüsselwort Top verwenden. In diesem Beispiel haben wir viele Aufzeichnungen über Erdbeben.
Jetzt wollen wir nur die ersten beiden Datensätze anzeigen
Step 1 - Gehen Sie zum Abfrage-Explorer und führen Sie diese Abfrage aus.
SELECT * FROM c
WHERE c.magnitude > 2.5
Sie werden sehen, dass vier Datensätze abgerufen wurden, da wir das Schlüsselwort TOP noch nicht angegeben haben.
Step 2- Verwenden Sie jetzt das Schlüsselwort TOP mit derselben Abfrage. Hier haben wir das Schlüsselwort TOP angegeben und '2' bedeutet, dass wir nur zwei Datensätze möchten.
SELECT TOP 2 * FROM c
WHERE c.magnitude > 2.5
Step 3 - Führen Sie nun diese Abfrage aus und Sie werden sehen, dass nur zwei Datensätze abgerufen werden.
Ebenso können Sie das Schlüsselwort TOP im Code mit dem .Net SDK verwenden. Es folgt die Implementierung.
private async static Task QueryDocumentsWithPaging(DocumentClient client) {
Console.WriteLine();
Console.WriteLine("**** Query Documents (paged results) ****");
Console.WriteLine();
Console.WriteLine("Quering for all documents");
var sql = "SELECT TOP 3 * FROM c";
var query = client
.CreateDocumentQuery(collection.SelfLink, sql)
.AsDocumentQuery();
while (query.HasMoreResults) {
var documents = await query.ExecuteNextAsync();
foreach (var document in documents) {
Console.WriteLine(" PublicId: {0}; Magnitude: {1};", document.publicid,
document.magnitude);
}
}
Console.WriteLine();
}
Es folgt die Aufgabe CreateDocumentClient, in der die DocumentClient- und Erdbebendatenbank instanziiert wird.
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 =
'earthquake'").AsEnumerable().First();
collection = client.CreateDocumentCollectionQuery(database.CollectionsLink,
"SELECT * FROM c WHERE c.id = 'earthquakedata'").AsEnumerable().First();
await QueryDocumentsWithPaging(client);
}
}
Wenn der obige Code kompiliert und ausgeführt wird, werden nur drei Datensätze abgerufen.
**** Query Documents (paged results) ****
Quering for all documents
PublicId: 2015p947400; Magnitude: 2.515176918;
PublicId: 2015p947373; Magnitude: 1.506774108;
PublicId: 2015p947329; Magnitude: 1.593394461;