gpt4 book ai didi

c# - MongoDB .Net 驱动 2.0 拉取(移除元素)

转载 作者:IT老高 更新时间:2023-10-28 13:08:56 25 4
gpt4 key购买 nike

你能帮我用 2.0 驱动程序正确运行“拉(删除)”吗?

我有一个这样的集合,我想通过关注者字段删除名为 fethiye 的第一个关注者。

{
"_id": ObjectId("554e05dfc90d3d4dfcaa2aea"),
"username": "bodrum",
"followerList": [
{
"_id": ObjectId("554e0625a51586362c33c6df"),
"follower": "fethiye",
"avatar": "fethiye.png"
},
{
"_id": ObjectId("554e0625a51586362c33c6df"),
"follower": "izmir",
"avatar": "izmir.png"
}
]
}

如何解决这个问题?

var filter = new BsonDocument("username", "bodrum");
var update = Builders<Person>.Update.Pull("followerList:follower", "fethiye");
Person pr = collection.FindOneAndUpdateAsync(filter, update).Result;

谢谢。

最佳答案

当使用过滤器移除数组元素时,需要使用PullFilter builder 而不是 Pull (匹配整个元素)。

var collection = db.GetCollection<Person>("people");
var filter = new BsonDocument("username", "bodrum");
var update = Builders<Person>.Update.PullFilter("followerList",
Builders<Follower>.Filter.Eq("follower", "fethiye"));
var result = collection.FindOneAndUpdateAsync(filter, update).Result;

或者更简洁一点,使用 lambda:

var update = Builders<Person>.Update.PullFilter(p => p.followerList,
f => f.follower == "fethiye");
var result = collection
.FindOneAndUpdateAsync(p => p.username == "bodrum", update).Result;

关于c# - MongoDB .Net 驱动 2.0 拉取(移除元素),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30141958/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com