Объединить два элемента массива в один на основе общего поля в MongoDB - PullRequest
0 голосов
/ 10 декабря 2018

У меня есть следующая коллекция (в формате Json) -

/* 1 */
{
    "_id" : NumberLong(1111),
    "valueArray" : [ 
        {
            "accountNumber" : NumberLong(12345),
            "levels" : [ 
                1, 
                13
            ]
        }, 
        {
            "accountNumber" : NumberLong(67890),
            "levels" : [ 
                2
            ]
        }
    ]
}

/* 2 */
{
    "_id" : NumberLong(2222),
    "valueArray" : [ 
        {
            "accountNumber" : NumberLong(33333),
            "levels" : [ 
                13, 
                1
            ]
        }, 
        {
            "accountNumber" : NumberLong(33333),
            "levels" : [ 
                8
            ]
        },
        {
            "accountNumber" : NumberLong(44444),
            "levels" : [ 
                5
            ]
        }
    ]
}

Обратите внимание на 2-й документ, в котором accountNumber совпадает (33333).Я хочу объединить их в одну запись.Вывод должен выглядеть следующим образом -

/* 1 */
{
    "_id" : NumberLong(1111),
    "valueArray" : [ 
        {
            "accountNumber" : NumberLong(12345),
            "levels" : [ 
                1, 
                13
            ]
        }, 
        {
            "accountNumber" : NumberLong(67890),
            "levels" : [ 
                2
            ]
        }
    ]
}

/* 2 */
{
    "_id" : NumberLong(2222),
    "valueArray" : [ 
        {
            "accountNumber" : NumberLong(33333),
            "levels" : [ 
                13, 
                1,
                8
            ]
        },
        {
            "accountNumber" : NumberLong(44444),
            "levels" : [ 
                5
            ]
        }
    ]
}

Я пробовал несколько подходов $ concatArrays, $ setUnion и т. Д., Но я заканчиваю получать ту или иную ошибку.Даже если я могу получить какой-либо вывод, он не в нужном формате.

Может кто-нибудь, пожалуйста, помогите здесь?

1 Ответ

0 голосов
/ 10 декабря 2018

Вы можете использовать double $ unwind для получения одного документа на valueArray.accountNumber и double $ group для агрегирования этих значений, сначала на accountNumber, а затем на _idпопробуйте:

db.col.aggregate([
    {
        $unwind: "$valueArray"
    },
    {
        $unwind: "$valueArray.levels"
    },
    {
        $group: {
            _id: {
                _id: "$_id",
                accountNumber: "$valueArray.accountNumber"
            },
            levels: { $push: "$valueArray.levels" }
        }
    },
    {
        $group: {
            _id: "$_id._id",
            valueArray: {
                $push: { accountNumber: "$_id.accountNumber", levels: "$levels" }
            }
        }
    }
])
...