添加到子 BsonDocument
Add to child BsonDocument
我有以下内容。有效。
private static async Task AddAndUpdateNestedDocument(IMongoCollection<BsonDocument> collection)
{
var key = "bert";
var filter = Builders<BsonDocument>.Filter.Exists(key);
await collection.DeleteManyAsync(filter);
var subkey = "friend";
var document = new BsonDocument(key, new BsonDocument(subkey, "ernie"));
await collection.InsertOneAsync(document);
var updater = Builders<BsonDocument>.Update.Set("sesame", "street");
await collection.UpdateOneAsync(filter, updater);
}
这运行没有错误。当我获取生成的文档时,它看起来像这样:
{ "_id" : ObjectId("5ef62acf152cc17a1c139f6d"), "bert" : { "friend" : "ernie" }, "sesame" : "street" }
没关系,但我真正想做的是让更新命令在“bert”子文档中插入“sesame”和“street”,这样它就这样结束了:
{ "_id" : ObjectId("5ef62acf152cc17a1c139f6d"), "bert" : { "friend" : "ernie", "sesame" : "street" } }
我该怎么做?
对于嵌套字段,您可以使用 dot notation:
Builders<BsonDocument>.Update.Set(key + ".sesame", "street");
我有以下内容。有效。
private static async Task AddAndUpdateNestedDocument(IMongoCollection<BsonDocument> collection)
{
var key = "bert";
var filter = Builders<BsonDocument>.Filter.Exists(key);
await collection.DeleteManyAsync(filter);
var subkey = "friend";
var document = new BsonDocument(key, new BsonDocument(subkey, "ernie"));
await collection.InsertOneAsync(document);
var updater = Builders<BsonDocument>.Update.Set("sesame", "street");
await collection.UpdateOneAsync(filter, updater);
}
这运行没有错误。当我获取生成的文档时,它看起来像这样:
{ "_id" : ObjectId("5ef62acf152cc17a1c139f6d"), "bert" : { "friend" : "ernie" }, "sesame" : "street" }
没关系,但我真正想做的是让更新命令在“bert”子文档中插入“sesame”和“street”,这样它就这样结束了:
{ "_id" : ObjectId("5ef62acf152cc17a1c139f6d"), "bert" : { "friend" : "ernie", "sesame" : "street" } }
我该怎么做?
对于嵌套字段,您可以使用 dot notation:
Builders<BsonDocument>.Update.Set(key + ".sesame", "street");