หากต้องการส่งองค์ประกอบไปยังอาร์เรย์ที่มีอยู่ ให้ใช้ตัวดำเนินการ $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"
]
}