210 votes

Comment trier en mangouste ?

Je ne trouve pas de doc pour le modificateur de tri. La seule idée est dans les tests unitaires : spec.lib.query.js#L12

writer.limit(5).sort(['test', 1]).group('name')

Mais ça ne marche pas pour moi :

Post.find().sort(['updatedAt', 1]);

223voto

iwein Points 4957

En Mongoose, un tri peut être fait de l'une des manières suivantes :

    Post.find({}).sort('test').exec(function(err, docs) { ... });
    Post.find({}).sort([['date', -1]]).exec(function(err, docs) { ... });
    Post.find({}).sort({test: 1}).exec(function(err, docs) { ... });
    Post.find({}, null, {sort: {date: 1}}, function(err, docs) { ... });

158voto

C'est ainsi que j'ai pu travailler dans la mangouste 2.3.0 :)

// Find First 10 News Items
News.find({
    deal_id:deal._id // Search Filters
},
['type','date_added'], // Columns to Return
{
    skip:0, // Starting Row
    limit:10, // Ending Row
    sort:{
        date_added: -1 //Sort by Date Added DESC
    }
},
function(err,allNews){
    socket.emit('news-load', allNews); // Do something with the array of 10 objects
})

72voto

Eric Points 171

MISE À JOUR :

Post.find().sort({'updatedAt': -1}).all((posts) => {
  // do something with the array of posts
});

Essayez :

Post.find().sort([['updatedAt', 'descending']]).all((posts) => {
  // do something with the array of posts
});

44voto

sultan aslam Points 359

Mongoose v5.x.x

trier par ordre croissant

Post.find({}).sort('field').exec(function(err, docs) { ... });
Post.find({}).sort({ field: 'asc' }).exec(function(err, docs) { ... });
Post.find({}).sort({ field: 'ascending' }).exec(function(err, docs) { ... });
Post.find({}).sort({ field: 1 }).exec(function(err, docs) { ... });

Post.find({}, null, {sort: { field : 'asc' }}), function(err, docs) { ... });
Post.find({}, null, {sort: { field : 'ascending' }}), function(err, docs) { ... });
Post.find({}, null, {sort: { field : 1 }}), function(err, docs) { ... });

trier par ordre décroissant

Post.find({}).sort('-field').exec(function(err, docs) { ... });
Post.find({}).sort({ field: 'desc' }).exec(function(err, docs) { ... });
Post.find({}).sort({ field: 'descending' }).exec(function(err, docs) { ... });
Post.find({}).sort({ field: -1 }).exec(function(err, docs) { ... });


Post.find({}, null, {sort: { field : 'desc' }}), function(err, docs) { ... });
Post.find({}, null, {sort: { field : 'descending' }}), function(err, docs) { ... });
Post.find({}, null, {sort: { field : -1 }}), function(err, docs) { ... });

Pour plus de détails :https://mongoosejs.com/docs/api.html #query_Query-sort

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X