ได้ คุณสามารถใช้ pull and add พร้อมกันกับตัวดำเนินการ $addToSet และ $pull ให้เราสร้างคอลเลกชันที่มีเอกสารก่อน
> db.pullAndAddToSetDemo.insertOne({StudentScores : [78, 89, 90]} ... ); { "acknowledged" : true, "insertedId" : ObjectId("5c9a797e15e86fd1496b38af") }
ต่อไปนี้เป็นแบบสอบถามเพื่อแสดงเอกสารทั้งหมดจากคอลเลกชันโดยใช้วิธี find()
> db.pullAndAddToSetDemo.find().pretty();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้
{ "_id" : ObjectId("5c9a797e15e86fd1496b38af"), "StudentScores" : [ 78, 89, 90 ] }
ต่อไปนี้เป็นแบบสอบถามที่จะดึงและ addtoset ในเวลาเดียวกันใน MongoDB
> var addAndPull = db.pullAndAddToSetDemo.initializeOrderedBulkOp(); > addAndPull.find({ "StudentScores": 89 }).updateOne({ "$addToSet": { "StudentScores": 99 } }); > addAndPull.find({ "StudentScores": 90 }).updateOne({ "$pull": { "StudentScores": 90 } }); > addAndPull.execute();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้
BulkWriteResult({ "writeErrors" : [ ], "writeConcernErrors" : [ ], "nInserted" : 0, "nUpserted" : 0, "nMatched" : 2, "nModified" : 2, "nRemoved" : 0, "upserted" : [ ] })
ให้เราตรวจสอบเอกสารอีกครั้งจากการรวบรวม ต่อไปนี้เป็นแบบสอบถาม
> db.pullAndAddToSetDemo.find().pretty();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้
{ "_id" : ObjectId("5c9a797e15e86fd1496b38af"), "StudentScores" : [ 78, 89, 99 ] }