myModel.find({}, function(err, items){
console.log(items.length); // big number
});
Как я могу ограничить возвращаемые элементы только последними 10 элементами, которые были вставлены?
myModel.find({}, function(err, items){
console.log(items.length); // big number
});
Как я могу ограничить возвращаемые элементы только последними 10 элементами, которые были вставлены?
В последнем мангусте (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
});
Подобным образом, используя .limit():
var q = models.Post.find({published: true}).sort('date', -1).limit(20);
q.execFind(function(err, posts) {
// `posts` will be of length 20
});
Я немного ленивый, поэтому мне нравятся простые вещи:
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
});
По какой-то причине я не мог заставить это работать с предлагаемыми ответами, но я нашел другой вариант, используя select, который работал у меня:
models.Post.find().sort('-date').limit(10).select('published').exec(function(e, data){
...
});
Возможно, апи изменилась? Я использую версию 3.8.19
... дополнительно обязательно используйте:
mongoose.Promise = Promise;
Это означает, что обещание мангуста соответствует обещанию ES6. Без этого добавления я получил:
DeprecationWarning: Mongoose: mpromise (библиотека обещаний по умолчанию mongoose) устарела, вместо этого добавьте свою собственную библиотеку обещаний: http://mongoosejs.com/docs/promises.html p >
Найти параметры
Параметры функции поиска:
"Object"
."Object|String"
необязательные поля для возврата, см. Query.prototype.select()"Object"
необязательно, см. Query.prototype.setOptions()"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) {});