ในการอัปเดตอาร์เรย์ด้วย $push ให้ใช้ updateOne() ใน MongoDB ให้เราสร้างคอลเลกชันที่มีเอกสาร -
> db.demo526.insertOne(
... {
...
... "CountryName": "US",
... "TeacherName": "Bob",
... "StudentInformation": [
... {
... "Name": "Chris",
... "Subject": "MySQL",
... "ListOfMailId":[]
... },
... {
... "Name": "David",
... "Subject": "MongoDB",
... "ListOfMailId":[]
...
... }
... ]
... }
... );
{
"acknowledged" : true,
"insertedId" : ObjectId("5e8af031437efc8605595b6b")
} แสดงเอกสารทั้งหมดจากคอลเล็กชันโดยใช้วิธี find() -
> db.demo526.find();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{ "_id" : ObjectId("5e8af031437efc8605595b6b"), "CountryName" : "US", "TeacherName" :
"Bob", "StudentInformation" : [ { "Name" : "Chris", "Subject" : "MySQL", "ListOfMailId" : [ ] }, {
"Name" : "David", "Subject" : "MongoDB", "ListOfMailId" : [ ] } ] } ต่อไปนี้เป็นแบบสอบถามเพื่ออัปเดตอาร์เรย์ด้วย $push -
> db.demo526.updateOne(
... {
... _id:ObjectId("5e8af031437efc8605595b6b"),
... "StudentInformation": { "$elemMatch": { "Name": "David", "Subject": "MongoDB" }}
... },
... {
... "$push": { "StudentInformation.$.ListOfMailId": { "MailId": "David@gmail.com" }}
...
... }
... )
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 } แสดงเอกสารทั้งหมดจากคอลเล็กชันโดยใช้วิธี find() -
> db.demo526.find();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{ "_id" : ObjectId("5e8af031437efc8605595b6b"), "CountryName" : "US", "TeacherName" : "Bob", "StudentInformation" : [
{ "Name" : "Chris", "Subject" : "MySQL", "ListOfMailId" : [ ] },
{ "Name" : "David", "Subject" : "MongoDB", "ListOfMailId" : [ { "MailId" : "David@gmail.com" } ] }
] }