myModel.find({}, function(err, items){
console.log(items.length); // big number
});
Comment puis-je limiter les articles retournés aux 10 derniers articles insérés?
Dans la dernière mangouste (3.8.1 au moment de l'écriture), vous faites deux choses différemment: (1) vous devez passer un seul argument à sort (), qui doit être un tableau de contraintes ou une seule contrainte, et (2 ) execFind () est parti et remplacé par exec (). Par conséquent, avec la mangouste 3.8.1, vous feriez ceci:
var q = models.Post.find({published: true}).sort({'date': -1}).limit(20);
q.exec(function(err, posts) {
// `posts` will be of length 20
});
ou vous pouvez le chaîner simplement comme ça:
models.Post
.find({published: true})
.sort({'date': -1})
.limit(20)
.exec(function(err, posts) {
// `posts` will be of length 20
});
Comme ceci, en utilisant .limit ():
var q = models.Post.find({published: true}).sort('date', -1).limit(20);
q.execFind(function(err, posts) {
// `posts` will be of length 20
});
Je suis un peu paresseux, alors j'aime les choses simples:
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
});
Pour une raison quelconque, je ne pouvais pas que cela fonctionne avec les réponses proposées, mais j'ai trouvé une autre variante, en utilisant select, qui a fonctionné pour moi:
models.Post.find().sort('-date').limit(10).select('published').exec(function(e, data){
...
});
L'API a peut-être changé? J'utilise la version 3.8.19
... en outre, assurez-vous d'utiliser:
mongoose.Promise = Promise;
Cela définit la promesse de la mangouste à la promesse de l'ES6 natif. Sans cet ajout, j'ai eu:
DeprecationWarning: Mongoose: mpromise (la bibliothèque de promesses par défaut de mongoose) est obsolète. Insérez votre propre bibliothèque de promesses à la place: http://mongoosejs.com/docs/promises.html
Trouver des paramètres
Les fonctions de recherche de paramètres sont les suivantes:
«Object»
.«Object|String»
champs facultatifs à renvoyer, voir Query.prototype.select ()«Object»
facultatif voir Query.prototype.setOptions ()«Function»
Comment limiter
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
}
);
Informations supplémentaires
Mongoose vous permet d’interroger vos collections de différentes manières, telles que: Documentation officielle
// 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) {});