หากต้องการส่งองค์ประกอบไปยังอาร์เรย์ที่มีอยู่ ให้ใช้ตัวดำเนินการ $addToSet พร้อมกับ update() ให้เราสร้างคอลเลกชันที่มีเอกสารก่อน -
> db.pushElements.insertOne({"Comments":["Good","Awesome","Nice"]}); { "acknowledged" : true, "insertedId" : ObjectId("5cd682597924bb85b3f48953") }
ต่อไปนี้เป็นแบบสอบถามเพื่อแสดงเอกสารทั้งหมดจากคอลเลกชันโดยใช้วิธี find() -
> db.pushElements.find().pretty();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{ "_id" : ObjectId("5cd682597924bb85b3f48953"), "Comments" : [ "Good", "Awesome", "Nice" ] }
ต่อไปนี้เป็นแบบสอบถามเพื่อส่งองค์ประกอบไปยังอาร์เรย์ที่มีอยู่ใน MongoDB -
> db.pushElements.update( {_id:ObjectId("5cd682597924bb85b3f48953")}, { "$addToSet":{"Comments":"Cool"} }, upsert=true ); WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
ให้เราตรวจสอบเอกสารอีกครั้ง -
> db.pushElements.find().pretty();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{ "_id" : ObjectId("5cd682597924bb85b3f48953"), "Comments" : [ "Good", "Awesome", "Nice", "Cool" ] }