$unwind
déconstruire le tableau rounds$project
pour afficher les champs obligatoires
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"
}
}
])
Une approche plus dynamique,
$mergeObjects
pour fusionner les champs obligatoires de la racine etround_values
objet$replaceRoot
pour remplacer l'objet fusionné ci-dessus à la racine
db.collection.aggregate([
{ $unwind: "$rounds" },
{
$replaceRoot: {
newRoot: {
$mergeObjects: [
{
GameID: "$GameID",
ComputerName: "$ComputerName"
},
"$rounds.round_values"
]
}
}
}
])