让 MongoDB 用字符串替换单个数组值?


使用 $set 和 positional($) 运算符进行替换。我们用文档创建一个集合 -

> db.demo564.insertOne({"StudentName":["Chris","David","Mike","Sam"]});{
   "acknowledged" : true, "insertedId" : ObjectId("5e90880a39cfeaaf0b97b576")
}

借助 find() 方法显示集合中的所有文档 -

> db.demo564.find().pretty();

这会生成以下输出 -

{
   "_id" : ObjectId("5e90880a39cfeaaf0b97b576"),
   "StudentName" : [
      "Chris",
      "David",
      "Mike",
      "Sam"
   ]
}

以下是用字符串替换单个数组值的查询 -

> db.demo564.updateMany(
...    { "StudentName": "David" },
...    { "$set": { "StudentName.$": "Carol Taylor" } }
... )
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }
>

借助 find() 方法显示集合中的所有文档 -

> db.demo564.find().pretty();

这会生成以下输出 -

{
   "_id" : ObjectId("5e90880a39cfeaaf0b97b576"),
   "StudentName" : [
      "Chris",
      "Carol Taylor",
      "Mike",
      "Sam"
   ]
}

更新于: 14-5-2020

581 次浏览

启动您的事业

完成课程获得认证

开始
广告