获取数组中的第一个元素,然后使用MongoDB Aggregate返回?
将$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" }
您可以使用$slice运算符find()
来获取数组中的第一个元素。以下是查询
> 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++" ] }
以上是 获取数组中的第一个元素,然后使用MongoDB Aggregate返回? 的全部内容, 来源链接: utcz.com/z/358016.html