配列を直接並べ替えることはできませんが、集計はそれを助けます
-
$unwind
アレイの構造を解除するのに役立ちます -
$sort
好きなように並べ替えるのに役立ちます -
$group
構造化されていないアレイを再グループ化するのに役立ちます
Mongoスクリプトを以下に示します
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"
}
}
}
])
作業中