作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想更新存储在 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"
}
]
}
]
]
}
}
}
])
关于mongodb - 如何更新mongo中列表最后一个对象的属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74719710/
我是一名优秀的程序员,十分优秀!