Compartilhar via


Gerenciar um documento no Azure Cosmos DB for MongoDB usando o .NET

APLICA-SE AO: MongoDB

Gerencie seus documentos do MongoDB com a capacidade de inserir, atualizar e excluir documentos.

Observação

Os trechos de código de exemplo estão disponíveis no GitHub como um projeto .NET.

Documentação de referência da API for MongoDB | Pacote do MongoDB (NuGet)

Inserir um documento

Insira um ou muitos documentos, definidos com um esquema JSON, em sua coleção.

// 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);

Atualizar um documento

Para atualizar um documento, especifique o filtro de consulta usado para localizar o documento com um conjunto de propriedades do documento que devem ser atualizadas.

// 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);

Atualizações em massa para uma coleção

Você pode executar diferentes tipos de operações ao mesmo tempo com a operação bulkWrite. Saiba mais sobre como otimizar as gravações em massa para o Azure Cosmos DB.

As opções em massa a seguir estão disponíveis:

// 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);

Excluir um documento

Para excluir documentos, use uma consulta para definir como os documentos são encontrados.

var deleteFilter = Builders<BsonDocument>.Filter.Eq("name", "Sand Surfboard Pro X");

collection.DeleteOne(deleteFilter);

Veja também