ใช้ตัวดำเนินการ $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++" ] }