使用快速路由器时如何实现MongoDB排序

问题描述 投票:0回答:1

我试图在Model.find()中使用MongoDB的默认排序算法之一,但是我无法弄清楚如何以这种方式实现排序功能。我知道它是如何工作的以及如何在mongo命令行中使用它,但无法弄清楚如何在这个庄园中实现它。

这是我到目前为止的代码,它完美地工作并返回我想要的值,但是我现在想要实现我在mySort中存储的排序来对返回的数据进行排序。

const express = require('express'),
    router = express.Router(),
    House = require('../models/house'),
    Event = require('../models/event');

router.get('/', function(req, res){

    var mySort = {totalPoints: -1};

    House.find({}, function(err, houses){
        if(err){
            console.log(err);
            res.redirect('/error');
        } else {
            res.render('houses/index', {pageTitle: 'Houses', houses: houses});
        }
    });
});

module.exports = router;

我希望houses将以totalPoints的降值值返回庄园。

javascript mongodb express mongoose express-router
1个回答
0
投票

试试这个语法:

House
   .find()
   .sort("-totalPoints") // or { "totalPoints" : -1 }
   .exec( houses => ... )

或者使用async / await:

const houses = await House.find().sort("-totalPoints")
© www.soinside.com 2019 - 2024. All rights reserved.