$unwind
desconstruir a matriz de rodadas$project
para mostrar os campos obrigatórios
db.collection.aggregate([
{ $unwind: "$rounds" },
{
$project: {
GameID: 1,
ComputerName: 1,
max_player_pot: "$rounds.round_values.max_player_pot",
pot_multiple: "$rounds.round_values.pot_multiple"
}
}
])
Playground
Uma abordagem mais dinâmica,
$mergeObjects
para mesclar campos obrigatórios da raiz eround_values
objeto$replaceRoot
para substituir o objeto mesclado acima pelo root
db.collection.aggregate([
{ $unwind: "$rounds" },
{
$replaceRoot: {
newRoot: {
$mergeObjects: [
{
GameID: "$GameID",
ComputerName: "$ComputerName"
},
"$rounds.round_values"
]
}
}
}
])
Playground