当前位置: 首页 > 编程笔记 >

使用$ set和location $运算符更新数组中的特定MongoDB文档?

孔运良
2023-03-14
本文向大家介绍使用$ set和location $运算符更新数组中的特定MongoDB文档?,包括了使用$ set和location $运算符更新数组中的特定MongoDB文档?的使用技巧和注意事项,需要的朋友参考一下

要使用$set和positional运算符更新数组中的特定文档,请使用MongoDB updateOne()。该updateOne()基于查询过滤器集合中更新单个文件。

让我们创建一个包含文档的集合-

> db.demo462.insertOne(
... {
...    "id":1,
...    "DueDateDetails": [
...       {
...          "Name": "David",
...          "Age":21,
...          "CountryName":["US","UK"]
...       },
...       {
...
...          "Name": "Chris",
...          "Age":23,
...          "CountryName":["UK"]
...       }
...    ]
... }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e7f6c59cb66ccba22cc9dce")
}

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

> db.demo462.find();

这将产生以下输出-

{ "_id" : ObjectId("5e7f6c59cb66ccba22cc9dce"), "id" : 1, "DueDateDetails" : [ { "Name" :
"David", "Age" : 21, "CountryName" : [ "US", "UK" ] }, { "Name" : "Chris", "Age" : 23,
"CountryName" : [ "UK" ] } ] }

以下是使用$set和positional $运算符使用updateOne()-更新数组中文档的查询-

> db.demo462.updateOne(
...    {id: 1, "DueDateDetails.Name": "Chris"},
...    { $set: { "DueDateDetails.$.CountryName": "AUS"} }
... )
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }

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

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

这将产生以下输出-

{
   "_id" : ObjectId("5e7f6c59cb66ccba22cc9dce"),
   "id" : 1,
   "DueDateDetails" : [
      {
         "Name" : "David",
         "Age" : 21,
         "CountryName" : [
            "US",
            "UK"
         ]
      },
      {
         "Name" : "Chris",
         "Age" : 23,
         "CountryName" : "AUS"
      }
   ]
}
 类似资料:
  • 在我的MongoDB中,我有文档,如下所示。如何更新内部文档结构中的文档:<code>〔{1},〔{2}〕,〔{3}〕、〔{4}〕</code>。 例如:子子文档中的子文档具有和以及 和

  • 问题内容: 我的文档中具有以下结构: 我想更新 someField 和 someField2, 但仅更新数组中的一项,与 _arrayId 匹配的 项 (例如;并且仅针对此文档(例如)),而不更新其他项。 该 arrayIds 是不是唯一的,这就是为什么我需要它是针对特定文档的文档。如果要为数组中存在的每个文档更新该值,则可以使用,但这不是我想要的。 我试图在Java中完成此操作,但也可以使用命令

  • 问题内容: 我正在尝试使用MongoDB的Java驱动程序在同一操作中对记录进行两次更新($ set和$ push)。我正在使用类似于以下代码: 当我通过BasicDBList将$ set和$ push合并到同一更新中时,我得到一个IllegalArgumentException:“存储在db中的字段不能以’$’开头(错误键:’$ push’)”。 如果我进行两个单独的更新,则pushUpdate

  • 我正在使用Spring Data MongoDB和Spring Data Rest创建一个Rest API,它允许对我的MongoDB数据库进行GET、POST、PUT和DELETE操作,除了更新操作(PUT)之外,其他操作都很好。只有当我在请求体中发送完整对象时,它才起作用。 我试着在这里搜索一个解决方案,但我只找到了以下帖子,但没有解决方案:如何使用MongoRepository接口更新mon

  • 问题内容: 我正在使用MongoDB数据库,该数据库的收集模型包括 班级 , 学生 , 学科 和[学术] 表现 。以下是基于猫鼬的架构和模型: 该集合的文件是最复杂的地段; 示例文档为: 我能够使用以下代码检索现有的班级文档并将其添加到分数中: 但是,如何添加/更新/删除该特定学生的成绩?我需要能够通过以下方式与集合进行交互: 检索所有学生或特定学生的分数(检索数组中的特定元素) 为特定主题添加/

  • 问题内容: 我正在尝试更新嵌套数组中的值,但无法使其正常工作。 我的对象是这样的 我需要将值推送到“ answeredBy”数组。 在下面的示例中,我尝试将“成功”字符串推到“ 123 _id”对象的“ answeredBy”数组中,但是它不起作用。 我找到了此链接,但其答案仅表示我应该使用类似结构的对象而不是数组。这不适用于我的情况。我真的需要将我的对象嵌套在数组中 如果您能在这里帮助我,那就太