sql >> Database teknologi >  >> NoSQL >> MongoDB

Hvordan bruger man MongoDB-aggregering til paginering?

For at beregne totaler og returnere et undersæt, skal du anvende gruppering og springe over/begrænse til det samme datasæt. Til det kan du bruge facetter

For eksempel for at vise 3. side, 10 dokumenter pr. side:

db.Order.aggregate([
    { '$match'    : { "company_id" : ObjectId("54c0...") } },
    { '$sort'     : { 'order_number' : -1 } },
    { '$facet'    : {
        metadata: [ { $count: "total" }, { $addFields: { page: NumberInt(3) } } ],
        data: [ { $skip: 20 }, { $limit: 10 } ] // add projection here wish you re-shape the docs
    } }
] )

Det vil returnere et enkelt dokument med 2 felter:

{
    "metadata" : [ 
        {
            "total" : 300,
            "page" : 3
        }
    ],
    "data" : [ 
        {
            ... original document ...
        }, 
        {
            ... another document ...
        }, 
        {
            ... etc up to 10 docs ...
        }
    ]
}



  1. Den hurtigere metode til at flytte redis-data til MySQL

  2. MongoDB virker ikke. FEJL:dbpath (/data/db) eksisterer ikke.

  3. Node - Mongoose 3.6 - Sorter forespørgsel med udfyldt felt

  4. Mongodb aggregeringsopslag med betingelser