[英]Multiple mongoose count() queries to a MongoDB
第一:我 - > MongoNoob,我知道这已经有过一种或另一种方式的问题,但到目前为止我还没有找到任何具体内容。 假设我有两个这样描述的Moongoose模型:
var pollSchema = mongoose.Schema({
title: String,
choices: [{
content: String
}]
});
var choiceSchema = mongoose.Schema({
poll_id: mongoose.Schema.ObjectId,
option: Number
});
UI显示轮询,当用户选择一个选项时,它将写入choiceSchema
模型。 现在我想创建一个'统计',告诉我有多少用户选择了选项1,选项2,选项3,....我可以简单地获取find
所有选项,并在服务器代码中生成统计信息,但是如果我有一百万用户选择,我将不得不处理相同大小的数组。 这不可能是对的。 然而,我可以生成一个查询并使用count()
方法:
var query = Choice.find({poll_id: someId}),
query.where('option', 1);
var resultForOption1;
query.count(function(err, count)) {
resultForOption1 = count;
});
我如何为多个选项执行此操作并将结果“加入”(哈哈)到数组中? 由于这是异步的,我会嵌套调用,但这不是可变数量的查询的选项。
我想念树木:-)? 有人能指出我正确的方向吗?
BR,丹尼尔
您可以使用aggregate
来执行此操作:
Choice.aggregate(
{$group: {_id: {poll_id: '$poll_id', option: '$option'}, count: {$sum: 1}}}
).exec(...);
这将按poll_id
和option
对choices
集合文档进行poll_id
,并计算每个文档的出现次数,从而提供如下输出:
{
"result": [
{
"_id": {
"poll_id": 2,
"option": 3
},
"count": 1
},
{
"_id": {
"poll_id": 1,
"option": 2
},
"count": 2
},
{
"_id": {
"poll_id": 2,
"option": 2
},
"count": 1
},
{
"_id": {
"poll_id": 1,
"option": 1
},
"count": 1
}
],
"ok": 1
}
然后,您可以在aggregate
管道中使用后续$group
和$project
阶段,以根据需要进一步对生成的文档进行分组和重新整形。
如果你想迭代count
查询并轻松清理你可以使用像co这样的lib甚至更好,async:
async.map({ "option":1 },{ "option":2 }], Choice.find, function(e, r){
// And you continue from here
});
另一个选择 - 在我看来更好 - 。 是使用聚合查询 。 您将了解有关mongoDB的更多信息,并且应该更有效率。 在我发给你的链接中,第一个例子几乎就是你想要做的:
(来源: mongodb.org )
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.