我在解决这个mongodb(猫鼬)问题时遇到了很多困难。
这个架构'推荐'(用户名,roomId,ll和日期),其集合包含用户推荐。
我需要获得最推荐的房间列表(按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'});
}
);
答案 0 :(得分:55)
聚合管道返回的结果只是普通对象。因此,您将排序作为管道阶段进行,而不是作为单独的操作:
Recommend.aggregate(
[
// Grouping pipeline
{ "$group": {
"_id": '$roomId',
"recommendCount": { "$sum": 1 }
}},
// Sorting pipeline
{ "$sort": { "recommendCount": -1 } },
// Optionally limit results
{ "$limit": 5 }
],
function(err,result) {
// Result is an array of documents
}
);
因此,有pipeline operators种$group
可用于$sort
或$limit
或{{3}}以及其他内容。这些可以按任何顺序呈现,并且可以根据需要多次呈现。只是理解一个“管道”阶段流动的结果将导致下一个行动。