We kunnen array niet direct sorteren, maar aggregatie helpt het
$unwind
helpt bij het de-structureren van de array$sort
helpt bij het sorteren zoals u wilt$group
helpt bij het hergroeperen van de gedestructureerde array
Mongo-script wordt hieronder gegeven
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"
}
}
}
])
Werkende Mongo-speeltuin