DocumentDB - Dokument abfragen

In DocumentDB verwenden wir SQL tatsächlich zum Abfragen von Dokumenten. In diesem Kapitel geht es also ausschließlich um das Abfragen mithilfe der speziellen SQL-Syntax in DocumentDB. Wenn Sie jedoch eine .NET-Entwicklung durchführen, gibt es auch einen LINQ-Anbieter, der verwendet werden kann und der aus einer LINQ-Abfrage geeignetes SQL generieren kann.

Dokument mit Portal abfragen

Das Azure-Portal verfügt über einen Abfrage-Explorer, mit dem Sie jede SQL-Abfrage für Ihre DocumentDB-Datenbank ausführen können.

Wir werden den Abfrage-Explorer verwenden, um die vielen verschiedenen Funktionen und Merkmale der Abfragesprache zu demonstrieren, beginnend mit der einfachsten möglichen Abfrage.

Step 1 - Klicken Sie im Datenbank-Blade auf, um das Query Explorer-Blade zu öffnen.

Denken Sie daran, dass Abfragen im Bereich einer Sammlung ausgeführt werden. Im Abfrage-Explorer können Sie die Sammlung in dieser Dropdown-Liste auswählen.

Step 2 - Wählen Sie Familiensammlung aus, die zuvor über das Portal erstellt wurde.

Der Abfrage-Explorer wird mit dieser einfachen Abfrage SELECT * FROM c geöffnet, mit der einfach alle Dokumente aus der Sammlung abgerufen werden.

Step 3- Führen Sie diese Abfrage aus, indem Sie auf die Schaltfläche 'Abfrage ausführen' klicken. Dann sehen Sie, dass das gesamte Dokument im Blade Ergebnisse abgerufen wird.

Abfragen des Dokuments mit dem .Net SDK

Im Folgenden finden Sie die Schritte zum Ausführen einiger Dokumentabfragen mit dem .Net SDK.

In diesem Beispiel möchten wir die neu erstellten Dokumente abfragen, die wir gerade hinzugefügt haben.

Step 1 - Rufen Sie CreateDocumentQuery auf und übergeben Sie die Auflistung, um die Abfrage anhand ihres SelfLink und des Abfragetextes auszuführen.

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 * 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(" Id: {0}; Name: {1};", document.id, document.name); 
      } 
   }
	
   Console.WriteLine(); 
}

Diese Abfrage gibt auch alle Dokumente in der gesamten Sammlung zurück, aber wir rufen nicht wie zuvor .ToList in CreateDocumentQuery auf, wodurch so viele Anforderungen wie nötig ausgegeben werden, um alle Ergebnisse in einer Codezeile abzurufen.

Step 2 - Rufen Sie stattdessen AsDocumentQuery auf, und diese Methode gibt ein Abfrageobjekt mit einer HasMoreResults-Eigenschaft zurück.

Step 3 - Wenn HasMoreResults true ist, rufen Sie ExecuteNextAsync auf, um den nächsten Block abzurufen, und sichern Sie dann den gesamten Inhalt dieses Blocks.

Step 4- Sie können auch mit LINQ anstelle von SQL abfragen, wenn Sie dies bevorzugen. Hier haben wir eine LINQ-Abfrage in q definiert, die jedoch erst ausgeführt wird, wenn wir .ToList darauf ausführen.

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} UK 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(); 
}

Das SDK konvertiert unsere LINQ-Abfrage in die SQL-Syntax für DocumentDB und generiert eine SELECT- und WHERE-Klausel basierend auf unserer LINQ-Syntax

Step 5 - Rufen Sie nun die obigen Abfragen aus der Task CreateDocumentClient auf.

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();  
			
      //await CreateDocuments(client); 
      await QueryDocumentsWithPaging(client); 
      QueryDocumentsWithLinq(client); 
   } 
	
}

Wenn der obige Code ausgeführt wird, erhalten Sie die folgende Ausgabe.

**** Query Documents (paged results) ****  
Quering for all documents 
 Id: 7e9ad4fa-c432-4d1a-b120-58fd7113609f; Name: New Customer 1; 
 Id: 34e9873a-94c8-4720-9146-d63fb7840fad; Name: New Customer 1;  
 
**** Query Documents (LINQ) **** 
Quering for US customers (LINQ) 
Found 2 UK 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