Come faccio a limitare il numero di elementi restituiti?
-
27-10-2019 - |
Domanda
myModel.find({}, function(err, items){
console.log(items.length); // big number
});
Come posso limitare gli oggetti restituiti a solo gli ultimi 10 elementi che sono stati inseriti?
Soluzione
Nell'ultima mangusta (3.8.1 al momento della scrittura), fare due cose in modo diverso: (1) si deve passare solo argomento a sort (), che deve essere un array di vincoli o solo un vincolo, e (2) execFind () è andato, e sostituiti 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
});
o è possibile concatenare insieme semplicemente così:
models.Post
.find({published: true})
.sort({'date': -1})
.limit(20)
.exec(function(err, posts) {
// `posts` will be of length 20
});
Altri suggerimenti
In questo modo, utilizzando .limit ():
var q = models.Post.find({published: true}).sort('date', -1).limit(20);
q.execFind(function(err, posts) {
// `posts` will be of length 20
});
Sono un po 'pigro, quindi mi piacciono le cose semplici:
let users = await Users.find({}, null,{limit: 50});
models.Post.find({published: true}, {sort: {'date': -1}, limit: 20}, function(err, posts) {
// `posts` with sorted length of 20
});
Per qualche motivo non ho potuto ottenere questo al lavoro con le risposte proposte, ma ho trovato un'altra variante, utilizzando select, che ha funzionato per me:
models.Post.find().sort('-date').limit(10).select('published').exec(function(e, data){
...
});
È l'API forse cambiato? Sto usando la versione 3.8.19
... inoltre assicurarsi di utilizzare:
mongoose.Promise = Promise;
Questo imposta la promessa mangusta alla promessa ES6 nativo. Senza questa aggiunta ho ottenuto:
DeprecationWarning: Mongoose: mpromise (libreria di default promessa di manguste) è deprecato, presa nella vostra libreria promessa invece: http://mongoosejs.com/docs/promises.html
Trova parametri
I parametri trovano funzione prende sono i seguenti:
- condizioni
«Object»
. - [proiezione]
«Object|String»
campi opzionali per tornare, vedi Query.prototype.select () - [opzioni]
«Object»
opzionale vedere Query.prototype.setOptions () - [callback]
«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
}
);
Ulteriori informazioni
Mongoose permette di interrogare le vostre collezioni in modi diversi, 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) {});