Как в Mongoose сортировать по дате?(узел.js)
Вопрос
скажем, я запускаю этот запрос в Mongoose:
Room.find({}, function(err,docs){
}).sort({date:-1});
Это не работает!
Решение
Сортировка В монгузе развивалась над выпусками, так что некоторые из этих ответов больше не действительны. Как 4.1.x освобождение Mongoose, нисходящего сорта на date
Поле может быть сделано любым из следующих способов:
Room.find({}).sort('-date').exec(function(err, docs) { ... });
Room.find({}).sort({date: -1}).exec(function(err, docs) { ... });
Room.find({}).sort({date: 'desc'}).exec(function(err, docs) { ... });
Room.find({}).sort({date: 'descending'}).exec(function(err, docs) { ... });
Room.find({}).sort([['date', -1]]).exec(function(err, docs) { ... });
Room.find({}, null, {sort: '-date'}, function(err, docs) { ... });
Room.find({}, null, {sort: {date: -1}}, function(err, docs) { ... });
Для восходящего вида, опустите -
префикс в строковой версии или используйте значения 1
, asc
, или же ascending
.
Другие советы
Правильный ответ:
Blah.find({}).sort({date: -1}).execFind(function(err,docs){
});
Сегодня я занимался этой проблемой, используя Mongoose 3.5(.2), и ни один из ответов не помог мне решить эту проблему.Следующий фрагмент кода делает свое дело
Post.find().sort('-posted').find(function (err, posts) {
// user posts array
});
Вы можете отправить любые стандартные параметры, которые вам нужны. find()
(например.где предложения и поля возврата), но нет перезвонить.Без обратного вызова он возвращает объект Query, который вы связываете sort()
на.Вам нужно позвонить find()
снова (с дополнительными параметрами или без них - они не нужны по соображениям эффективности), что позволит вам получить набор результатов в обратном вызове.
Я делаю это:
Data.find( { $query: { user: req.user }, $orderby: { dateAdded: -1 } } function ( results ) {
...
})
Это покажет самые последние вещи в первую очередь.
Post.find().sort({date:-1}, function(err, posts){
});
Должен работать так же
РЕДАКТИРОВАТЬ:
Вы также можете попробовать использовать это, если получите ошибку sort() only takes 1 Argument
:
Post.find({}, {
'_id': 0, // select keys to return here
}, {sort: '-date'}, function(err, posts) {
// use it here
});
Посмотрите, поможет ли это> Как сортировать в монгузе?
Также прочитайте это> http://www.mongodb.org/display/docs/sorting+andnatural+
Короткое решение:
const query = {}
const projection = {}
const options = { sort: { id: 1 }, limit: 2, skip: 10 }
Room.find(query, projection, options).exec(function(err, docs) { ... });