【问题标题】:MongoDB update arrays entryMongoDB 更新数组条目
【发布时间】:2021-12-24 22:09:56
【问题描述】:

我有一个文档要像这样的 Mongodb 更新对象数组:

    {
    "myArray": [
            {
              "Key1": "string",
              "key2": {
                "entry": "aaa"
              }
            },
            {
              "Key1": "string",
              "key2": {
                "entry": "bbb"
              }
            }
          ]
    }

我想修改 myArray 的每个对象中的 key2 字段。预期的结果应该是:

    {
    "myArray": [
            {
              "Key1": "string",
              "key2Modified":"aaa"
            },
            {
              "Key1": "string",
              "key2Modified":"bbb"
            }
          ]
    }

有什么帮助吗?

【问题讨论】:

标签: arrays mongodb mongodb-query spring-data-mongodb


【解决方案1】:

$set 中使用$map

db.collection.update({},
[
  {
    $set: {
      "myArray": {
        $map: {
          input: "$myArray",
          as: "a",
          in: {
            Key1: "$$a.Key1",
            key2Modified: "$$a.key2.entry"
          }
        }
      }
    }
  }
])

mongoplayground

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2015-11-28
    • 1970-01-01
    • 2013-01-21
    • 2015-03-29
    • 2016-08-10
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多