Як обмежити кількість повернених предметів?


113
myModel.find({}, function(err, items) {
    console.log(items.length);    // Big number
});

Як я можу обмежити повернуті елементи лише останніми 10 предметами, які були вставлені?

Відповіді:


188

В останньому мангусті (3.8.1 на момент написання) ви робите дві речі по-різному: (1) вам потрібно передавати один аргумент для сортування (), який повинен бути масивом обмежень або лише одним обмеженням, і (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
  });

що означає {'дата': -1}? Спасибі заздалегідь!
kurumkan

3
@ArslArsl - результати будуть відсортовані за датою у порядку декадування.
NL Довгий

@ArslArsl це схоже на наступне: { date: 'desc' } {date: 'descending'}. Дивіться цю відповідь
rotimi-best

Чи існує максимум для обмеження?
lukas_o

20

Так, використовуючи .limit ():

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

2
Велике спасибі, не знав, що ви можете робити такі запити. Де я можу знайти якусь форму документації щодо цього методу execFind?
Запуск черепахи

Чесно кажучи, я просто дивлюсь на приклади мангустських джерел та інших матеріалів, а також на тестові приклади. Список розсилки також хороший. Фактичні документи здаються трохи застарілими.
kcbanner

1
є execFind ще в останній версії mongoosejs?
Менні

2
@Manny Це не так. Дивіться відповідь marni для оновленої версії.
JohnnyHK

15

Я трохи ледачий, тому мені подобаються прості речі:

let users = await Users.find({}, null, {limit: 50});

8
models.Post.find({published: true}, {sort: {'date': -1}, limit: 20}, function(err, posts) {
 // `posts` with sorted length of 20
});

5
Хоча цей фрагмент коду може вирішити питання, включаючи пояснення, як і чому це вирішує проблему , справді допоможе покращити якість вашої публікації. Пам’ятайте, що ви відповідаєте на запитання читачів у майбутньому, а не лише про людину, яка зараз запитує! Будь ласка, відредагуйте свою відповідь, щоб додати пояснення та вказати, які обмеження та припущення застосовуються.
Toby Speight

2

Знайдіть параметри

Функція пошуку параметрів приймає такі:

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

Додаткова інформація

Мангуст дозволяє запитувати колекції різними способами, як-от: Офіційна документація

// 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) {});

1

Чомусь я не міг змусити це працювати з запропонованими відповідями, але знайшов інший варіант, використовуючи select, який працював для мене:

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

Чи змінився апі? Я використовую версію 3.8.19


1

... додатково переконайтесь у використанні:

mongoose.Promise = Promise;

Це встановлює мангустну обіцянку до рідної обіцянки ES6. Без цього доповнення я отримав:

DeprecationWarning: Mongoose: mpromise (бібліотека обіцянок за замовчуванням мангуста) застаріла, замість цього підключіть власну бібліотеку обіцянок: http://mongoosejs.com/docs/promises.html

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.