我正在尝试聚合一批文件。我想要推送的文件中有两个字段。但是,让我们说他们是" _id"和" A"字段,我只想要$ push" _id"和" A"如果" A"是$ gt 0。
我尝试了两种方法。
第一个。
db.collection.aggregate([{
"$group":{
"field": {
"$push": {
"$cond":[
{"$gt":["$A", 0]},
{"id": "$_id", "A":"$A"},
null
]
}
},
"secondField":{"$push":"$B"}
}])
但是这会将空值推送到"字段"而且我不想要它。
第二个。
db.collection.aggregate([{
"$group":
"field": {
"$cond":[
{"$gt",["$A", 0]},
{"$push": {"id":"$_id", "A":"$A"}},
null
]
},
"secondField":{"$push":"$B"}
}])
第二个根本不起作用......
有没有办法在其他情况下跳过$ push?
增加:
预期文件:
{
"_id":objectid(1),
"A":2,
"B":"One"
},
{
"_id":objectid(2),
"A":3,
"B":"Two"
},
{
"_id":objectid(3),
"B":"Three"
}
预期产出:
{
"field":[
{
"A":"2",
"_id":objectid(1)
},
{
"A":"3",
"_id":objectid(2)
},
],
"secondField":["One", "Two", "Three"]
}
答案 0 :(得分:12)
您可以使用"$$REMOVE"
:
db.collection.aggregate([{
$group:{
field: {
$push: {
$cond:[
{ $gt: ["$A", 0] },
{ id: "$_id", A:"$A" },
"$$REMOVE"
]
}
},
secondField:{ $push: "$B" }
}
])
通过这种方式,您不必过滤null。
答案 1 :(得分:6)
在阅读@Veeram建议的帖子后,这是我对这个问题的回答
db.collection.aggregate([{
"$group":{
"field": {
"$push": {
"$cond":[
{"$gt":["$A", 0]},
{"id": "$_id", "A":"$A"},
null
]
}
},
"secondField":{"$push":"$B"}
},
{
"$project": {
"A":{"$setDifferrence":["$A", [null]]},
"B":"$B"
}
}])
答案 2 :(得分:1)
还有一个选择是使用$ filter运算符:
db.collection.aggregate([
{
$group : {
_id: null,
field: { $push: { id: "$_id", A : "$A"}},
secondField:{ $push: "$B" }
}
},
{
$project: {
field: {
$filter: {
input: "$field",
as: "item",
cond: { $gt: [ "$$item.A", 0 ] }
}
},
secondField: "$secondField"
}
}])
在第一步中,您将组合数组并在第二步中过滤它们