Utwórz wirtualne pole, które reprezentuje wartość wpisów, które powinny być wyświetlane na górze listy, a następnie posortuj wpisy na podstawie tego pola. Możesz użyć $addFields
i $cond
operatorów, aby to osiągnąć.
Implementacja wyglądałaby mniej więcej tak:
// ...
{
"$addFields": {
"isFeaturedSort": {
"$cond": {
"if": {
"$and": {
"publishDate": {
"$gte": ISODate("2019-03-14T00:00:00.000Z"),
},
"$eq": ["isFeatured", true],
},
},
"then": 1,
"else": 0,
},
},
},
},
{
"$sort": {
"isFeaturedSort": -1, // changed
"refreshes.refreshAt": -1,
"publishDate": -1,
"_id": -1,
},
},
// ...
Zwróć uwagę, że $addField
działa tylko w MongoDB 3.4 i dalej. Również fragmenty kodu mogą zawierać błędy.