透過 MongoDB 同時提取並新增到 set?這可能嗎?


是的,你可以使用 $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
   ]
}

以下是 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
   ]
}

更新於: 30-Jul-2019

704 次瀏覽

開啟你的 職業生涯

完成課程並獲得認證

開始
廣告
© . All rights reserved.