通过 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.