Gestire un documento in Azure Cosmos DB for MongoDB usando .NET
SI APPLICA A: MongoDB
Gestire i documenti di MongoDB con la possibilità di eseguire operazioni di inserimento, aggiornamento ed eliminazione.
Nota
I frammenti di codice di esempio sono disponibili su GitHub come progetto .NET.
Documentazione di riferimento dell'API per MongoDB | Pacchetto MongoDB (NuGet)
Inserire un documento
Inserire uno o più documenti definiti con uno schema JSON nella raccolta.
// insert one document
var product = new BsonDocument
{
{ "name", "Sand Surfboard" },
{ "category", "gear-surf-surfboards" },
{ "count", 1 }
};
collection.InsertOne(product);
// insert many documents
var products = new List<BsonDocument>()
{
new BsonDocument
{
{ "name", "Lake Surfboard" },
{ "category", "gear-surf-surfboards" },
{ "count", 1 }
},
new BsonDocument
{
{ "name", "Ocean Surfboard" },
{ "category", "gear-surf-surfboards" },
{ "count", 5 }
}
};
collection.InsertMany(products);
Aggiornare un documento
Per aggiornare un documento, specificare il filtro di query usato per trovare il documento insieme a un set di proprietà del documento da aggiornare.
// update one item
var filter = Builders<BsonDocument>.Filter.Eq("name", "Sand Surfboard");
var update = Builders<BsonDocument>.Update.Set("name", "Sand Surfboard Pro");
collection.UpdateOne(filter, update);
//update many items
var filterMany = Builders<BsonDocument>.Filter.Eq("category", "gear-surf-surfboards");
var updateMany = Builders<BsonDocument>.Update.Set("category", "gear-surfboards");
collection.UpdateMany(filterMany, updateMany);
Aggiornamenti bulk di una raccolta
È possibile eseguire diversi tipi di operazioni contemporaneamente con l'operazione bulkWrite. Altre informazioni su come ottimizzare le scritture bulk per Azure Cosmos DB.
Sono disponibili le operazioni bulk seguenti:
MongoClient.Database.Collection.BulkWrite
insertOne
updateOne
updateMany
deleteOne
deleteMany
// perform multiple different types of operations
var models = new WriteModel<BsonDocument>[]
{
new InsertOneModel<BsonDocument>(new BsonDocument(new BsonDocument
{
{ "name", "Wave Paddleboard" },
{ "category", "gear-surfboards" },
{ "count", 1 }
})),
new UpdateOneModel<BsonDocument>(
Builders<BsonDocument>.Filter.Eq("name", "Sand Surfboard Pro"),
Builders<BsonDocument>.Update.Set("name", "Sand Surfboard Pro X")),
new DeleteOneModel<BsonDocument>(new BsonDocument("name", "Ocean Surfboard"))
};
collection.BulkWrite(models);
Eliminazione di un documento
Per eliminare i documenti, usare una query per definire la modalità di individuazione dei documenti.
var deleteFilter = Builders<BsonDocument>.Filter.Eq("name", "Sand Surfboard Pro X");
collection.DeleteOne(deleteFilter);