mongo更新脚本:更改嵌入式文档中的字段

时间:2019-07-09 08:51:52

标签: javascript mongodb document

我正在编写一个脚本来更新(添加和重命名)某些字段,这些字段是db集合中存储的嵌入式文档的一部分。

给出示例文件:

{
    _id: UUID("025bda29-0d09-4923-8f7f-ea2e825be2c8"),
    name: "test",
    sets: [
       {
           "name": "1",
           "values": [
               {
                   name: "a",
                   value: 5
               }
           ]
       },
       {
           "name": "2",
           "values": [
               {
                   name: "a",
                   value: 3
               }
           ]
       }
   ]
}

这是我的脚本:

function convertGroup (group) {
    for (var i = 0; i < group.sets.length; i++) {
        var set = group.sets[i];
        var oldValuesField = "sets." + i.toString() + ".values";
        var mainValuesField = "sets." + i.toString() + "mainValues";
        var additionalValuesField = "sets." + i.toString() + ".additionalValues";
        db.getCollection('group').updateOne({ 
            "_id" : group._id 
        }, { 
            $set: {
                mainValuesField : set.values,
                additionalValuesField : [ ] 
            },
            $unset: {
                oldValuesField: ""
            }
        });
    }
}
db.getCollection('group').find({'sets.0.mainValues': {$exists: false}}).forEach(convertGroup);

根据文档,$ rename在数组上不起作用,这就是为什么我使用set和unset的原因。

运行此代码时发生的情况是,我在文档中获得了 mainValues 字段和 additionalValues 字段,而不是设置文档。

这就是我想要成为的:

{
    _id: UUID("025bda29-0d09-4923-8f7f-ea2e825be2c8"),
    name: "test",
    sets: [
       {
           "name": "1",
           "mainValues": [
               {
                   name: "a",
                   value: 5
               }
           ],
           "additionalValues": [ ]
        },
        {
           "name": "2",
           "mainValues": [
               {
                   name: "a",
                   value: 3
               }
           ],
           "additionalValues": [ ]
        }
    ]
}

任何人都可以向我解释为什么会发生这种情况以及如何按照我希望的方式进行这项工作吗?

1 个答案:

答案 0 :(得分:1)

我设法通过重写脚本来解决此问题:

function convertGroup(group) {

    group.sets.forEach(function (set) {
        if (!set.mainValues) {
            $set : {
                set.mainValues = set.values
            }
       }

        if (!set.additionalValues) {
            $set : {
                set.additionalValues = []
            }
        }
    });
    db.getCollection('group').update({'_id': group._id}, group);
}
db.getCollection('group').find({'sets.mainValues': {$exists: false}}).forEach(convertGroup)

区别主要是不使用符号“ sets。[index] .values”,而是直接在json上对其进行编辑,并使用“ update”而不是“ updateOne”