如何使用 MongoDB 聚合來獲取陣列中的第一個元素並返回?


使用 $unwind 運算子和 $project 獲取陣列中的第一個元素。讓我們建立一個包含文件的集合。以下為查詢

>db.getFirstElementInArrayDemo.insertOne({"StudentName":"John","StudentSubject":["MongoDB","Python","MySQL"]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c9c41292d6669774125244e")
}
>db.getFirstElementInArrayDemo.insertOne({"StudentName":"Chris","StudentSubject":["Java","C"]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c9c413f2d6669774125244f")
}
>db.getFirstElementInArrayDemo.insertOne({"StudentName":"Robert","StudentSubject":["C++","Ruby"]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c9c41532d66697741252450")
}

以下為使用 find() 方法顯示集合中所有文件的查詢

> db.getFirstElementInArrayDemo.find().pretty();

這將產生以下輸出

{
   "_id" : ObjectId("5c9c41292d6669774125244e"),
   "StudentName" : "John",
   "StudentSubject" : [
      "MongoDB",
      "Python",
      "MySQL"
   ]
}
{
   "_id" : ObjectId("5c9c413f2d6669774125244f"),
   "StudentName" : "Chris",
   "StudentSubject" : [
      "Java",
      "C"
   ]
}
{
   "_id" : ObjectId("5c9c41532d66697741252450"),
   "StudentName" : "Robert",
   "StudentSubject" : [
      "C++",
      "Ruby"
   ]
}

以下為使用聚合獲取陣列中的第一個元素並返回的查詢

> db.getFirstElementInArrayDemo.aggregate([
...    {$unwind:"$StudentSubject"},
...    {$group:{"_id":"$_id","FirstElement":{$first:"$StudentSubject"}}},
...    {$project:{"_id":0,"FirstElement":1}}
... ]);

這將產生以下輸出

{ "FirstElement" : "Java" }
{ "FirstElement" : "C++" }
{ "FirstElement" : "MongoDB" }

可以在 find() 中使用 $slice 運算子獲取陣列中的第一個元素。以下為查詢

> db.getFirstElementInArrayDemo.find({},{"StudentSubject":{$slice:1}});

這將產生以下輸出

{ "_id" : ObjectId("5c9c41292d6669774125244e"), "StudentName" : "John", "StudentSubject" : [ "MongoDB" ] }
{ "_id" : ObjectId("5c9c413f2d6669774125244f"), "StudentName" : "Chris", "StudentSubject" : [ "Java" ] }
{ "_id" : ObjectId("5c9c41532d66697741252450"), "StudentName" : "Robert", "StudentSubject" : [ "C++" ] }

更新於:2019 年 7 月 30 日

2K+ 瀏覽量

開啟您的職業生涯

完成課程,獲得認證

開始
廣告
© . All rights reserved.