sql >> Databasteknik >  >> NoSQL >> MongoDB

hitta och räkna i en enda mongodb-fråga

Detta är ett perfekt jobb för aggregeringsramverket.

db.course.aggregate(
    [
        { "$sort": { "created_at": -1 }},
        { "$group": {
            "_id": null, 
            "docs": { "$push": "$$ROOT" }, 
            "count": { "$sum": 1 }
        }},
        { "$project": { "_id": 0, "count": 1, "docs": { "$slice": [ "$docs", 5 ] } }}
    ]
)

Om din MongoDB-server inte stöder $slice då måste du använda det fula och ineffektiva tillvägagångssättet.

db.course.aggregate(
    [
        { "$sort": { "created_at": -1 }},
        { "$group": {
            "_id": null, 
            "docs": { "$push": "$$ROOT" }, 
            "count": { "$sum": 1 }
        }},
        { "$unwind": "$docs" },
        { "$limit": 5 }
    ]
)


  1. MongoDB atomic uppdatering via "sammanfoga" dokument

  2. MongoDB sorterar på barn

  3. MongoDB index skärningspunkt

  4. Välj dokument där alla värden i ett matrisfält finns i en annan matris