我正在解决mongodb(mongoose)问题时遇到了很大的困难。
有这个模式'Recommend'(用户名,房间ID,以及日期),它的集合包含用户的推荐。
我需要获取最受推荐的房间列表(按roomId排序)。以下是模式和我的用mongoose查询尝试的解决方案。
var recommendSchema = mongoose.Schema({
username: String,
roomId: String,
ll: { type: { type: String }, coordinates: [ ] },
date: Date
})
recommendSchema.index({ ll: '2dsphere' });
var Recommend = mongoose.model('Recommend', recommendSchema);
Recommend.aggregate(
{
$group:
{
_id: '$roomId',
recommendCount: { $sum: 1 }
}
},
function (err, res) {
if (err) return handleError(err);
var resultSet = res.sort({'recommendCount': 'desc'});
}
);