Mongodb 使用多个嵌套文档更新文档字段

Mongodb 使用多个嵌套文档更新文档字段,mongodb,mongodb-query,nested-documents,Mongodb,Mongodb Query,Nested Documents,我有一个现有的MongoDB文档,其中包含字段文件(以及其他字段)。files字段是一个对象,现在我想用几个嵌套文档更新这个字段。我已成功插入一个具有以下语法的嵌套文档: db.collection.updateOne( { "id": 1 }, { $set: { "files": { "filename1": { "a": "Lorem ip

我有一个现有的MongoDB文档,其中包含字段
文件
(以及其他字段)。
files
字段是一个对象,现在我想用几个嵌套文档更新这个字段。我已成功插入一个具有以下语法的嵌套文档:

db.collection.updateOne(
    { "id": 1 },
    {
        $set: {
            "files":
            {
                "filename1": {
                    "a": "Lorem ipsum dolor",
                    "b": "Sit amet consectetur",
                    "c": "Adipiscing elit"
                }
            }
        }
    })
接下来,我尝试在
文件
字段中同时插入另外两个文档,但失败了

db.collection.updateOne(
    { "id": 1 },
    {
        $set: {
            "files":
            {
                "filename2": {
                    "d": "Lorem ipsum dolor",
                    "e": "Sit amet consectetur",
                    "f": "Adipiscing elit"
                }
            }
{
        "filename3": {
            "g": "Duis aute irure",
            "h": "Labore et dolore",
            "i": "Eiusmod tempor incididunt"
        }
    }
}})
在这不起作用之后,我尝试使用第一个代码块逐个插入记录,但插入了
filename2
(我不想覆盖现有的
filename1
)。此文档已插入到
文件
对象中,但重写了现有文档
filename1
。我尝试了几种不同的变体,但都不起作用


关于如何在一个字段中嵌套多个文档的任何反馈/帮助都会很有帮助。

因为更新查询没有什么问题,所以它不起作用,请检查以下内容:

db.collection.updateOne(
    { "id": 1 },
    {
        $set: {
            "files":
            {
                "filename2": {
                    "d": "Lorem ipsum dolor",
                    "e": "Sit amet consectetur",
                    "f": "Adipiscing elit"
                },
                "filename3": {
                    "g": "Duis aute irure",
                    "h": "Labore et dolore",
                    "i": "Eiusmod tempor incididunt"
                }
            }
        }
    })
上面的查询可以工作,但这里有一个问题-它将用发送的新的
文件替换现有的
文件
字段,因为您使用的
$set
将用新值替换现有字段(如果旧值与新值不同)

如果
文件
是一个数组,您可以使用
$push
$addToSet
向现有的
文件
字段添加新值(然后您只需将
$set
替换为其中一个即可),但如果您希望将
文件
作为对象,您需要读取它并在代码中使用
符号注入新值,并使用
$set
将整个
文件写回MongoDB,这是对DB的两次调用。另一方面,您可以通过以下方式在一个DB调用中完成:

db.updateObject.updateOne({"id": 1}, {
    $set: {
       /** Same like programming language you use `.`,
           You're not replacing files rather you're adding new objects to files,
           If 'files.filename2' already exists in DB then it would be updated. */
        'files.filename2': {
            "d": "Lorem ipsum dolor",
            "e": "Sit amet consectetur",
            "f": "Adipiscing elit"
        }, 'files.filename3': {
            "g": "Duis aute irure",
            "h": "Labore et dolore",
            "i": "Eiusmod tempor incididunt"
        }
    }
})
这将使用两个新对象更新
文件
对象:

/* 1 */
{
    "_id" : ObjectId("5e179dac627ef7823643cd97"),
    "id" : 1,
    "files" : {
        "filename1" : {
            "a" : "Lorem ipsum dolor",
            "b" : "Sit amet consectetur",
            "c" : "Adipiscing elit"
        },
        "filename2" : {
            "d" : "Lorem ipsum dolor",
            "e" : "Sit amet consectetur",
            "f" : "Adipiscing elit"
        },
        "filename3" : {
            "g" : "Duis aute irure",
            "h" : "Labore et dolore",
            "i" : "Eiusmod tempor incididunt"
        }
    }
}

您的第二个查询有语法问题,请检查下面的答案。工作完美,感谢您的帮助!