DocumentDB - Dokument aktualisieren

In diesem Kapitel erfahren Sie, wie Sie die Dokumente aktualisieren. Mit dem Azure-Portal können Sie Dokumente einfach aktualisieren, indem Sie das Dokument im Dokument-Explorer öffnen und im Editor wie eine Textdatei aktualisieren.

Klicken Sie auf die Schaltfläche "Speichern". Wenn Sie jetzt ein Dokument mit dem .Net SDK ändern müssen, können Sie es einfach ersetzen. Sie müssen es nicht löschen und neu erstellen, was nicht nur mühsam ist, sondern auch die Ressourcen-ID ändert, was Sie nicht möchten, wenn Sie nur ein Dokument ändern. Führen Sie die folgenden Schritte aus, um das Dokument mithilfe des .Net SDK zu aktualisieren.

Werfen wir einen Blick auf die folgende ReplaceDocuments-Aufgabe, in der wir nach Dokumenten abfragen, bei denen die isNew-Eigenschaft wahr ist, aber keine erhalten, da keine vorhanden sind. Ändern wir also die zuvor hinzugefügten Dokumente, deren Namen mit "Neuer Kunde" beginnen.

Step 1 - Fügen Sie diesen Dokumenten die Eigenschaft isNew hinzu und setzen Sie ihren Wert auf true.

private async static Task ReplaceDocuments(DocumentClient client) {

   Console.WriteLine(); 
   Console.WriteLine(">>> Replace Documents <<<"); 
   Console.WriteLine();  
   Console.WriteLine("Quering for documents with 'isNew' flag");
	
   var sql = "SELECT * FROM c WHERE c.isNew = true"; 
   var documents = client.CreateDocumentQuery(collection.SelfLink, sql).ToList();
	
   Console.WriteLine("Documents with 'isNew' flag: {0} ", documents.Count); 
   Console.WriteLine();  
   Console.WriteLine("Quering for documents to be updated"); 
	
   sql = "SELECT * FROM c WHERE STARTSWITH(c.name, 'New Customer') = true"; 
   documents = client.CreateDocumentQuery(collection.SelfLink, sql).ToList(); 
   Console.WriteLine("Found {0} documents to be updated", documents.Count); 
	
   foreach (var document in documents) {
      document.isNew = true; 
      var result = await client.ReplaceDocumentAsync(document._self, document); 
      var updatedDocument = result.Resource; 
      Console.WriteLine("Updated document 'isNew' flag: {0}", updatedDocument.isNew); 
   }
	
   Console.WriteLine();  
   Console.WriteLine("Quering for documents with 'isNew' flag");
	
   sql = "SELECT * FROM c WHERE c.isNew = true"; 
   documents = client.CreateDocumentQuery(collection.SelfLink, sql).ToList(); 
   Console.WriteLine("Documents with 'isNew' flag: {0}: ", documents.Count); 
   Console.WriteLine(); 
}

Step 2 - Holen Sie sich die zu aktualisierenden Dokumente mit derselben STARTSWITH-Abfrage und das gibt uns die Dokumente, die wir hier als dynamische Objekte zurückbekommen.

Step 3 - Fügen Sie die Eigenschaft isNew hinzu und setzen Sie sie für jedes Dokument auf true.

Step 4 - Rufen Sie ReplaceDocumentAsync auf und übergeben Sie den SelfLink des Dokuments zusammen mit dem aktualisierten Dokument.

Um zu beweisen, dass dies funktioniert hat, fragen Sie nach Dokumenten, bei denen isNew gleich true ist. Rufen Sie die obigen Abfragen aus der CreateDocumentClient-Task 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);  
      //QueryDocumentsWithSql(client); 
      //await QueryDocumentsWithPaging(client); 
      //QueryDocumentsWithLinq(client); 
      await ReplaceDocuments(client); 
   }
	
}

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

**** Replace Documents ****  
Quering for documents with 'isNew' flag 
Documents with 'isNew' flag: 0 
Quering for documents to be updated 
Found 2 documents to be updated 
Updated document ‘isNew’ flag: True 
Updated document ‘isNew’ flag: True 
Quering for documents with 'isNew' flag 
Documents with 'isNew' flag: 2