Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> MongoDB

ค้นหาวัตถุสุดท้ายของอาร์เรย์ด้วย MongoDB


ในการสอบถามออบเจ็กต์สุดท้ายของอาร์เรย์ ให้ใช้ aggregate() ให้เราสร้างคอลเลกชันที่มีเอกสาร -

> db.demo103.insertOne( { "Details" : [
   { "StudentId" : 101, "Details" : "MongoDB" },
   {"StudentId" : 102, "Details" : "MySQL" },
   { "StudentId" : 103, "Details" : "Java" } 
], "Details1" : [ { "StudentId" : 104, "Number" : 3 } ] } );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e2ed2dd9fd5fd66da21446e")
}

แสดงเอกสารทั้งหมดจากคอลเล็กชันโดยใช้วิธี find() -

> db.demo103.find();

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

{ "_id" : ObjectId("5e2ed2dd9fd5fd66da21446e"), "Details" : [ { "StudentId" : 101, "Details" : "MongoDB" }, { "StudentId" : 102, "Details" : "MySQL" }, { "StudentId" : 103, "Details" : "Java" } ], "Details1" : [ { "StudentId" : 104, "Number" : 3 } ] }

นี่คือวิธีที่คุณสามารถสอบถามไปยังวัตถุสุดท้ายของอาร์เรย์ -

> db.demo103.aggregate([ { $project: { Details1: 1, Details: {$arrayElemAt: ["$Details", -1]} } }, { $match: {"Details.StudentId": 103} } ])

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

{ "_id" : ObjectId("5e2ed2dd9fd5fd66da21446e"), "Details1" : [ { "StudentId" : 104, "Number" : 3 } ], "Details" : { "StudentId" : 103, "Details" : "Java" } }