Come limitare il numero di articoli restituiti?


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

Come posso limitare gli articoli restituiti solo agli ultimi 10 articoli inseriti?

Risposte:


188

Nell'ultima mongoose (3.8.1 al momento della scrittura), fai due cose in modo diverso: (1) devi passare un singolo argomento a sort (), che deve essere un array di vincoli o solo un vincolo, e (2 ) execFind () è sparito e sostituito con exec () invece. Pertanto, con la mangusta 3.8.1 faresti questo:

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

oppure puoi incatenarlo insieme semplicemente in questo modo:

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

cosa significa {'date': -1}? Grazie in anticipo!
kurumkan

3
@ArslArsl: i risultati verranno ordinati per data in ordine decrescente.
NL Long

@ArslArsl è simile al seguente: { date: 'desc' } {date: 'descending'}. Vedi questa risposta
rotimi-best

C'è un limite massimo?
lukas_o

20

In questo modo, usando .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
Grazie mille, non sapevo che potessi fare domande del genere. Dove posso trovare qualche forma di documentazione su questo metodo execFind?
Running Turtle

Onestamente, guardo solo gli esempi nelle fonti e nel materiale di mangusta, così come i casi di prova. Anche la mailing list è buona. I documenti attuali sembrano un po 'datati.
kcbanner

1
execFind è ancora nell'ultima versione di mongoosejs?
Manny

2
@Manny Non lo è. Vedi la risposta di Marni per una versione aggiornata.
JohnnyHK

15

Sono un po 'pigro, quindi mi piacciono le cose semplici:

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
Sebbene questo snippet di codice possa risolvere la domanda, inclusa una spiegazione di come e perché questo risolve il problema aiuterebbe davvero a migliorare la qualità del tuo post. Ricorda che stai rispondendo alla domanda per i lettori in futuro, non solo alla persona che lo chiede ora! Si prega di modificare la risposta di aggiungere una spiegazione, e dare un'indicazione di ciò si applicano le limitazioni e le assunzioni.
Toby Speight

2

Trova parametri

I parametri della funzione find sono i seguenti:

  1. condizioni «Object».
  2. [proiezione] «Object|String»campi opzionali da restituire, vedere Query.prototype.select ()
  3. [opzioni] «Object»opzionale vedere Query.prototype.setOptions ()
  4. [richiama] «Function»

Come limitare

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

Informazioni extra

Mongoose ti consente di interrogare le tue raccolte in diversi modi come: Documentazione ufficiale

// 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

Per qualche motivo non sono riuscito a farlo funzionare con le risposte proposte, ma ho trovato un'altra variazione, usando select, che ha funzionato per me:

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

L'API è forse cambiata? Sto usando la versione 3.8.19


1

... inoltre assicurati di utilizzare:

mongoose.Promise = Promise;

Questo imposta la promessa della mangusta alla promessa ES6 nativa. Senza questa aggiunta ho ottenuto:

Avviso: Mongoose: mpromise (la libreria di promesse predefinita di mongoose) è deprecata, collega invece la tua libreria di promesse: http://mongoosejs.com/docs/promises.html

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.