Non possiamo ordinare direttamente l'array, ma l'aggregazione lo aiuta
$unwind
aiuta a destrutturare l'array$sort
aiuta a ordinare come desideri$group
aiuta a raggruppare nuovamente l'array destrutturato
Lo script Mongo è riportato di seguito
db.collection.aggregate([
{
"$match": {
"serviceAreas.slug": "nashville"
}
},
{
$unwind: "$serviceAreas"
},
{
$sort: {
"serviceAreas.totalClosedSales": -1
}
},
{
$addFields: {
total: "$serviceAreas.totalClosedSales"
}
},
{
$sort: {
total: -1
}
},
{
$group: {
_id: "$_id",
mlsId: {
$first: "$mlsId"
},
firstName: {
$first: "$firstName"
},
lastName: {
$first: "$lastName"
},
slug: {
$first: "$slug"
},
serviceAreas: {
$push: "$serviceAreas"
}
}
}
])
Lavoro parco giochi Mongo