javascript – 对MongoDB的多个mongoose count()查询
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 对MongoDB的多个mongoose count()查询,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1470字,纯文字阅读大概需要3分钟。
内容图文
![javascript – 对MongoDB的多个mongoose count()查询](/upload/InfoBanner/zyjiaocheng/911/532f4557dc6e438197dd8978df189fa0.jpg)
第一:我 – > MongoNoob和我知道这已经以一种或另一种方式被问到了,但直到现在我还没有找到任何具体内容.
假设我有两个这样描述的Moongoose模型:
var pollSchema = mongoose.Schema({
title: String,
choices: [{
content: String
}]
});
var choiceSchema = mongoose.Schema({
poll_id: mongoose.Schema.ObjectId,
option: Number
});
UI显示轮询,当用户选择一个选项时,它将写入choiceSchemamodel.现在我想创建一个’统计’,告诉我有多少用户选择了选项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,
丹尼尔
解决方法:
您可以使用聚合来执行此操作:
Choice.aggregate(
{$group: {_id: {poll_id: '$poll_id', option: '$option'}, count: {$sum: 1}}}
).exec(...);
这将按poll_id和option对选择集合文档进行分组,并计算每个文档的出现次数,从而提供如下输出:
{
"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
}
然后,您可以在聚合管道中使用后续$group和$project阶段,以根据需要进一步对生成的文档进行分组和重新整形.
内容总结
以上是互联网集市为您收集整理的javascript – 对MongoDB的多个mongoose count()查询全部内容,希望文章能够帮你解决javascript – 对MongoDB的多个mongoose count()查询所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。