MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Как да използвам агрегирането на MongoDB за пагинация?

За изчисляване на сумии върнете подмножество, трябва да приложите групиране и да пропуснете/ограничите към същия набор от данни. За това можете да използвате фасети

Например за показване на 3-та страница, 10 документа на страница:

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
    } }
] )

Той ще върне един документ с 2 полета:

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



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. много към много отношения с nosql (mongodb и mongoose)

  2. MongoDB ИЗБЕРЕТЕ БРОЙ ГРУПА ОТ

  3. MongoDB изтеглящ елемент от масив от колекция

  4. Изтрийте всичко в база данни на MongoDB

  5. Етапи на MongoDB Aggregation Framework и тръбопроводи