Administración de un documento en Azure Cosmos DB for MongoDB mediante .NET
SE APLICA A: MongoDB
Administre los documentos de MongoDB con la capacidad de insertar, actualizar y eliminar documentos.
Nota:
Los fragmentos de código de ejemplo están disponibles en GitHub como un proyecto de .NET.
Documentación de referencia de la API para MongoDB | Paquete de MongoDB (NuGet)
Inserción de un documento
Inserte uno o varios documentos, definidos con un esquema JSON, en la colección.
// 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);
Actualización de un documento
Para actualizar un documento, especifique el filtro de consulta utilizado para buscar el documento junto con un conjunto de propiedades del documento que se deben actualizar.
// 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);
Actualizaciones masivas de una colección
Puede realizar distintos tipos de operaciones a la vez con la operación bulkWrite. Obtenga más información sobre cómo optimizar operaciones de escritura masivas para Azure Cosmos DB.
Se encuentran disponibles las siguientes operaciones masivas:
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);
Eliminar un documento
Para eliminar documentos, use una consulta para definir cómo se encuentran los documentos.
var deleteFilter = Builders<BsonDocument>.Filter.Eq("name", "Sand Surfboard Pro X");
collection.DeleteOne(deleteFilter);