mongodb的$项目是否有可能返回一个数组?

时间:2013-10-21 18:23:55

标签: node.js mongodb aggregation-framework

MongoDb的$ project聚合运算符是否可以将文档重组为数组?

这是我到目前为止所做的:

var pipeline = [];
var project = {
    $project : {
        x: "$_id", 
        y: "$y" ,
        _id : 0
    }
};
pipeline.push(project);
model.aggregate( pipeline, callback);

这给了我输出形式:

[
  { 
   x: '...',
   y: '...'
  }
 ....
]

我想:

[
   ['..','..']
   ....
]

我可以通过迭代来轻松地重构输出,但是真的很想知道聚合本身是否可以返回数组而不是对象。

2 个答案:

答案 0 :(得分:4)

您可以尝试使用$ push运算符。

例如, 如果您有以下文件:

{ _id: <something>, y: 5 } 

在mongo shell中,如果键入

db.model.aggregate( [ { $group: { _id: null, newArrayField: { $push: {  x: "$_id", y: "$y"  } } } } ] )

你会得到:

{
    "result" : [
        {
            "_id" : null,
            "newArrayField" : [
                {
                    "x" : ObjectId("5265dd479eb4b1d4289cf222"),
                    "y" : 5
                }
            ]
        }
    ],
    "ok" : 1
}

有关$ push运算符的详细信息,请参阅http://docs.mongodb.org/manual/reference/operator/aggregation/push/

答案 1 :(得分:0)

使用MongoDB 3.2,您可以project array values

db.model.aggregate({
  $project: {arrayField: ['$_id', '$y']}
})