Использовать агрегацию $ макс.Так как $ max является оператором-аккумулятором, доступным только на этапе $ group, вам нужно сделать хитрость.В операторе группы используйте любую константу как _id.
Давайте рассмотрим пример, приведенный на сайте Mongodb * только 1003 * -
Рассмотрим коллекцию sales со следующими документами:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-03T09:05:00Z") }
{ "_id" : 4, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-02-15T08:00:00Z") }
{ "_id" : 5, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T09:05:00Z") }
Если вы хотите узнать максимальную цену среди всех предметов.
db.sales.aggregate(
[
{
$group:
{
_id: "1", //** This is the trick
maxPrice: { $max: "$price" }
}
}
]
)
Обратите внимание, что значение «_id» - это «1».Вы можете поставить любую константу ...