sql >> Base de Datos >  >> NoSQL >> MongoDB

¿Cómo puedo obtener los valores más bajos en una colección de MongoDB?

Debe $group sus documentos por "precio". A partir de ahí, $sort por "_id" en orden ascendente y use $limit para devolver el primer documento que no es más que el documento con el valor mínimo.

db.products.aggregate([ 
    { "$group": { 
        "_id": "$price", 
        "docs": { "$push": "$$ROOT" } 
    }},
    { "$sort": { "_id": 1 } }, 
    { "$limit": 1 } 
])

que produce algo como:

{
    "_id" : 100,
    "docs" : [
        {
            "_id" : ObjectId("574a161b17569e552e35edb5"),
            "product" : "Milk",
            "barcode" : 12345,
            "price" : 100,
            "store" : "BestBuy"
        },
        {
            "_id" : ObjectId("574a161b17569e552e35edb6"),
            "product" : "Milk",
            "barcode" : 12345,
            "price" : 100,
            "store" : "WalMart"
        }
    ]
}