gpt4 book ai didi

mongodb - 如何更新mongo中列表最后一个对象的属性

转载 作者:行者123 更新时间:2023-12-05 03:16:18 25 4
gpt4 key购买 nike

我想更新存储在 mongo 列表中的最后一个对象的属性。出于性能原因,我无法从列表中弹出对象,然后更新属性,然后将对象放回原处。我也不能更改代码设计,因为它不依赖于我。简而言之,我正在寻找一种方法来选择列表的最后一个元素。

我最接近它的工作是使用 arrayFilters,我发现它正在研究这个主题(mongodb 核心票:https://jira.mongodb.org/browse/SERVER-27089):

db.getCollection("myCollection")
.updateOne(
{
_id: ObjectId('638f5f7fe881c670052a9d08')
},
{
$set: {"theList.$[i].propertyToUpdate": 'NewValueToAssign'}
},
{
arrayFilters: [{'i.type': 'MyTypeFilter'}]
}
)

我使用过滤器仅更新 theList 中的对象,这些对象的属性 type 被评估为 MyTypeFilter

我正在寻找的是这样的东西:

db.getCollection("maCollection")
.updateOne(
{
_id: ObjectId('638f5f7fe881c670052a9d08')
},
{
$set: {"theList.$[i].propertyToUpdate": 'NewValueToAssign'}
},
{
arrayFilters: [{'i.index': -1}]
}
)

我也尝试使用 "theList.$last.propertyToUpdate" 而不是 "theList.$[i].propertyToUpdate" 但无法识别路径(因为 $last 无效)

我在网上找不到与我的情况相符的内容。

谢谢你的帮助,祝你今天愉快

最佳答案

您想使用 Mongo 的 pipelined updates ,这允许我们在更新主体中使用聚合运算符。

但是,您确实需要考虑以前的答案没有考虑的边缘情况。 (null 列表、 列表和list.length == 1)

整体看起来是这样的:

db.collection.update({
_id: ObjectId("638f5f7fe881c670052a9d08")
},
[
{
$set: {
list: {
$concatArrays: [
{
$cond: [
{
$gt: [
{
$size: {
$ifNull: [
"$list",
[]
]
}
},
1
]
},
{
$slice: [
"$list",
0,
{
$subtract: [
{
$size: "$list"
},
1
]
}
]
},
[]
]
},
[
{
$mergeObjects: [
{
$ifNull: [
{
$last: "$list"
},
{}
]
},
{
propertyToUpdate: "NewValueToAssign"
}
]
}
]
]
}
}
}
])

Mongo Playground

关于mongodb - 如何更新mongo中列表最后一个对象的属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74719710/

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