将数组中的第一项投影到新字段(MongoDB聚合)

时间:2016-08-28 22:59:12

标签: mongodb mongoose aggregation-framework

我正在使用Mongoose聚合(MongoDB版本3.2)。

我有一个字段users,它是一个数组。我希望将此数组中的$project第一项添加到新字段user

我试过

  { $project: {
    user: '$users[0]',
    otherField: 1
  }},

  { $project: {
    user: '$users.0',
    otherField: 1
  }},

  { $project: {
    user: { $first: '$users'},
    otherField: 1
  }},

但两者都不起作用。

我该怎么做才能正确?感谢

3 个答案:

答案 0 :(得分:58)

您可以使用arrayElemAt

{ $project: {
    user: { $arrayElemAt: [ "$users", 0 ] },
    otherField: 1
}},

答案 1 :(得分:6)

如果它是一个对象数组并且您只想使用单个对象字段,即:

{
 "users": [
    {name: "John", surname: "Smith"},
    {name: "Elon", surname: "Gates"}
   ]
}

你可以使用:

{ $project: { user: { $first: "$users.name" } } 

答案 2 :(得分:2)

Mongo 4.4开始,聚合运算符$first可用于访问数组的第一个元素:

// { "users": ["Jean", "Paul", "Jack"] }
// { "users": ["Claude"] }
db.collection.aggregate([
  { $project: { user: { $first: "$users" } } }
])
// { "user" : "Jean" }
// { "user" : "Claude" }