gpt4 book ai didi

mongodb - 如何在 Mongo 中合并列

转载 作者:行者123 更新时间:2023-12-04 09:45:41 25 4
gpt4 key购买 nike

我有这个问题,我似乎无法解决它。

我的数据示例:

[
{'item': 'U',
'field_1': 3,
'field_2': 1,
'field_3': 1,
'field_4': 2,
'field_5': 5,
:
:
:
},
{'item': 'Y',
'field_1': 9,
'field_2': 2,
'field_3': 3,
'field_4': 5,
'field_5': 1,
:
:
:
}
]

我想创建一个名为 REST 的新字段,它将是不在我的输入数组 ( [field_1, field_5] ) 中的字段的总和。

我想要的结果是这样的(对于输入 [field_1, field_5] ):
[
{'item': 'U',
'REST': 13,
},
{'item': 'Y',
'REST': 20
}
]

Mongo 大师请帮助!,深深地感谢它。谢谢!

最佳答案

您可以使用 $objectToArray$filter为达到这个:

db.collection.aggregate([
{
$addFields: {
rootAsArray: {
$filter: {
input: {$objectToArray: "$$ROOT"},
as: "field",
cond: {
$and: [
{$ne: ["$$field.k", "_id"]},
{$ne: ["$$field.k", "item"]},
...any other field that's not relevant, you can also just add these to input arr ...

{$not: {$setIsSubset: [["$$field.k"], ["field_1", "field_5"]]}}
]
}
}
}
}
},
{
$project: {
item: "$item",
OTHER: {
$sum: {
$map: {
input: "$rootAsArray",
as: "value",
in: "$$value.v"
}
}
}
}
}
]);

关于mongodb - 如何在 Mongo 中合并列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62128612/

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