DocumentDB - Sammlung löschen
Um Sammlungen oder Sammlungen zu löschen, können Sie dies sowohl über das Portal als auch über den Code mithilfe des .Net SDK tun.
Step 1- Wechseln Sie zu Ihrem DocumentDB-Konto im Azure-Portal. Zum Zweck der Demo habe ich zwei weitere Sammlungen hinzugefügt, wie im folgenden Screenshot gezeigt.
Step 2- Um eine Sammlung zu löschen, müssen Sie auf diese Sammlung klicken. Wählen wir TempCollection1 aus. Auf der folgenden Seite wird die Option "Sammlung löschen" ausgewählt.
Step 3- Es wird die Bestätigungsmeldung angezeigt. Klicken Sie nun auf die Schaltfläche "Ja".
Sie werden sehen, dass TempCollection1 in Ihrem Dashboard nicht mehr verfügbar ist.
Sie können Sammlungen auch mit dem .Net SDK aus Ihrem Code löschen. Führen Sie dazu die folgenden Schritte aus.
Step 1 - Löschen wir die Sammlung, indem wir die ID der Sammlung angeben, die wir löschen möchten.
Es ist das übliche Muster, nach ID abzufragen, um die zum Löschen einer Ressource erforderlichen selfLinks zu erhalten.
private async static Task DeleteCollection(DocumentClient client, string collectionId) {
Console.WriteLine();
Console.WriteLine("**** Delete Collection {0} in {1} ****", collectionId, database.Id);
var query = new SqlQuerySpec {
QueryText = "SELECT * FROM c WHERE c.id = @id",
Parameters = new SqlParameterCollection {
new SqlParameter {
Name = "@id", Value = collectionId
}
}
};
DocumentCollection collection = client.CreateDocumentCollectionQuery(database.SelfLink,
query).AsEnumerable().First();
await client.DeleteDocumentCollectionAsync(collection.SelfLink);
Console.WriteLine("Deleted collection {0} from database {1}", collectionId,
database.Id);
}
Hier sehen wir die bevorzugte Methode zum Erstellen einer parametrisierten Abfrage. Wir haben die collectionId nicht fest codiert, daher kann diese Methode zum Löschen jeder Sammlung verwendet werden. Wir fragen nach einer bestimmten Auflistung nach ID ab, wobei der Id-Parameter in dieser SqlParameterCollection definiert ist, die der Eigenschaft des Parameters dieser SqlQuerySpec zugewiesen ist.
Anschließend erstellt das SDK die endgültige Abfragezeichenfolge für DocumentDB mit der darin eingebetteten collectionId.
Step 2 - Führen Sie die Abfrage aus und löschen Sie die Sammlung mit ihrem SelfLink aus der CreateDocumentClient-Task.
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();
await DeleteCollection(client, "TempCollection");
}
}
Im Folgenden finden Sie die vollständige Implementierung der Datei Program.cs.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Microsoft.Azure.Documents;
using Microsoft.Azure.Documents.Client;
using Microsoft.Azure.Documents.Linq;
using Newtonsoft.Json;
namespace DocumentDBDemo {
class Program {
private const string EndpointUrl = "https://azuredocdbdemo.documents.azure.com:443/";
private const string AuthorizationKey = "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/
StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";
private static Database database;
static void Main(string[] args) {
try {
CreateDocumentClient().Wait();
} catch (Exception e) {
Exception baseException = e.GetBaseException();
Console.WriteLine("Error: {0}, Message: {1}", e.Message, baseException.Message);
}
Console.ReadKey();
}
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();
await DeleteCollection(client, "TempCollection");
//await CreateCollection(client, "MyCollection1");
//await CreateCollection(client, "MyCollection2", "S2");
////await CreateDatabase(client);
//GetDatabases(client);
//await DeleteDatabase(client);
//GetDatabases(client);
}
}
private async static Task CreateCollection(DocumentClient client,
string collectionId, string offerType = "S1") {
Console.WriteLine();
Console.WriteLine("**** Create Collection {0} in {1} ****", collectionId,
database.Id);
var collectionDefinition = new DocumentCollection { Id = collectionId };
var options = new RequestOptions { OfferType = offerType };
var result = await client.CreateDocumentCollectionAsync(database.SelfLink,
collectionDefinition, options);
var collection = result.Resource;
Console.WriteLine("Created new collection");
ViewCollection(collection);
}
private static void ViewCollection(DocumentCollection collection) {
Console.WriteLine("Collection ID: {0} ", collection.Id);
Console.WriteLine("Resource ID: {0} ", collection.ResourceId);
Console.WriteLine("Self Link: {0} ", collection.SelfLink);
Console.WriteLine("Documents Link: {0} ", collection.DocumentsLink);
Console.WriteLine("UDFs Link: {0} ", collection.UserDefinedFunctionsLink);
Console.WriteLine("StoredProcs Link: {0} ", collection.StoredProceduresLink);
Console.WriteLine("Triggers Link: {0} ", collection.TriggersLink);
Console.WriteLine("Timestamp: {0} ", collection.Timestamp);
}
private async static Task DeleteCollection(DocumentClient client,
string collectionId) {
Console.WriteLine();
Console.WriteLine("**** Delete Collection {0} in {1} ****", collectionId,
database.Id);
var query = new SqlQuerySpec {
QueryText = "SELECT * FROM c WHERE c.id = @id", Parameters = new
SqlParameterCollection {
new SqlParameter {
Name = "@id", Value = collectionId
}
}
};
DocumentCollection collection = client.CreateDocumentCollectionQuery
(database.SelfLink, query).AsEnumerable().First();
await client.DeleteDocumentCollectionAsync(collection.SelfLink);
Console.WriteLine("Deleted collection {0} from database {1}", collectionId,
database.Id);
}
}
}
Wenn der obige Code kompiliert und ausgeführt wird, erhalten Sie die folgende Ausgabe.
**** Delete Collection TempCollection in myfirstdb ****
Deleted collection TempCollection from database myfirstdb