Как я могу ограничить количество возвращаемых товаров? - PullRequest
98 голосов
/ 29 апреля 2011
myModel.find({}, function(err, items){
console.log(items.length);    // big number
});

Как я могу ограничить возвращаемые товары только 10 последними вставленными предметами?

Ответы [ 7 ]

164 голосов
/ 15 декабря 2013

В последнем мангусте (3.8.1 на момент написания) вы делаете две вещи по-разному: (1) вам нужно передать один аргумент для sort (), который должен быть массивом ограничений или только одним ограничением, и (2) execFind () ушел и заменен на exec (). Поэтому с мангустом 3.8.1 вы бы сделали это:

var q = models.Post.find({published: true}).sort({'date': -1}).limit(20);
q.exec(function(err, posts) {
     // `posts` will be of length 20
});

или вы можете связать это вместе просто так:

models.Post
.find({published: true})
.sort({'date': -1})
.limit(20)
.exec(function(err, posts) {
     // `posts` will be of length 20
});
19 голосов
/ 29 апреля 2011

Вот так, используя .limit ():

var q = models.Post.find({published: true}).sort('date', -1).limit(20);
q.execFind(function(err, posts) {
  // `posts` will be of length 20
});
8 голосов
/ 22 декабря 2018

Я немного ленив, поэтому мне нравятся простые вещи:

let users = await Users.find({}, null,{limit: 50});
4 голосов
/ 07 февраля 2017
models.Post.find({published: true}, {sort: {'date': -1}, limit: 20}, function(err, posts) {
 // `posts` with sorted length of 20
});
1 голос
/ 01 сентября 2017

... дополнительно убедитесь, что используете:

mongoose.Promise = Promise;

Это устанавливает обещание мангуста для обещания ES6.Без этого дополнения я получил:

DeprecationWarning: Mongoose: mpromise (библиотека обещаний по умолчанию mongoose) устарела, вместо этого подключите собственную библиотеку обещаний: http://mongoosejs.com/docs/promises.html

1 голос
/ 07 декабря 2014

По какой-то причине я не мог заставить это работать с предложенными ответами, но я нашел другой вариант, используя select, который работал для меня:

models.Post.find().sort('-date').limit(10).select('published').exec(function(e, data){
        ...
});

Возможно, API изменился? Я использую версию 3.8.19

0 голосов
/ 30 апреля 2019

Параметры поиска

Функция поиска параметров имеет следующие параметры:

  1. условия «Object».
  2. [проекция] «Object|String» необязательные поля для возврата, см. Query.prototype.select ()
  3. [опции] «Object» необязательно см. Query.prototype.setOptions ()
  4. [обратный вызов] «Function»

Как ограничить

const Post = require('./models/Post');

Post.find(
  { published: true }, 
  null, 
  { sort: { 'date': 'asc' }, limit: 20 },
  function(error, posts) {
   if (error) return `${error} while finding from post collection`;

   return posts; // posts with sorted length of 20
  }
);

Дополнительная информация

Mongoose позволяет запрашивать ваши коллекции различными способами, такими как: Официальная документация

// named john and at least 18
MyModel.find({ name: 'john', age: { $gte: 18 }});

// executes, passing results to callback
MyModel.find({ name: 'john', age: { $gte: 18 }}, function (err, docs) {});

// executes, name LIKE john and only selecting the "name" and "friends" fields
MyModel.find({ name: /john/i }, 'name friends', function (err, docs) { })

// passing options
MyModel.find({ name: /john/i }, null, { skip: 10 })

// passing options and executes
MyModel.find({ name: /john/i }, null, { skip: 10 }, function (err, docs) {});

// executing a query explicitly
var query = MyModel.find({ name: /john/i }, null, { skip: 10 })
query.exec(function (err, docs) {});

// using the promise returned from executing a query
var query = MyModel.find({ name: /john/i }, null, { skip: 10 });
var promise = query.exec();
promise.addBack(function (err, docs) {});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...