DocumentDB - Dokument löschen
In diesem Kapitel erfahren Sie, wie Sie ein Dokument aus Ihrem DocumentDB-Konto löschen. Mit Azure Portal können Sie jedes Dokument einfach löschen, indem Sie das Dokument im Dokument-Explorer öffnen und auf die Option "Löschen" klicken.
Es wird die Bestätigungsmeldung angezeigt. Klicken Sie nun auf die Schaltfläche Ja und Sie werden sehen, dass das Dokument in Ihrem DocumentDB-Konto nicht mehr verfügbar ist.
Jetzt, wenn Sie ein Dokument mit dem .Net SDK löschen möchten.
Step 1- Es ist das gleiche Muster wie zuvor, bei dem wir zuerst nach den SelfLinks jedes neuen Dokuments fragen. Wir verwenden hier nicht SELECT *, wodurch die Dokumente in ihrer Gesamtheit zurückgegeben werden, was wir nicht benötigen.
Step 2 - Stattdessen wählen wir nur die SelfLinks in einer Liste aus und rufen dann für jeden SelfLink nacheinander DeleteDocumentAsync auf, um die Dokumente aus der Sammlung zu löschen.
private async static Task DeleteDocuments(DocumentClient client) {
Console.WriteLine();
Console.WriteLine(">>> Delete Documents <<<");
Console.WriteLine();
Console.WriteLine("Quering for documents to be deleted");
var sql =
"SELECT VALUE c._self FROM c WHERE STARTSWITH(c.name, 'New Customer') = true";
var documentLinks =
client.CreateDocumentQuery<string>(collection.SelfLink, sql).ToList();
Console.WriteLine("Found {0} documents to be deleted", documentLinks.Count);
foreach (var documentLink in documentLinks) {
await client.DeleteDocumentAsync(documentLink);
}
Console.WriteLine("Deleted {0} new customer documents", documentLinks.Count);
Console.WriteLine();
}
Step 3 - Rufen wir nun die obigen DeleteDocuments 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 DeleteDocuments(client);
}
}
Wenn der obige Code ausgeführt wird, erhalten Sie die folgende Ausgabe.
***** Delete Documents *****
Quering for documents to be deleted
Found 2 documents to be deleted
Deleted 2 new customer documents