- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
基本上,我想将对mongo的两个单独的调用合并为一个单独的调用,但是我不确定如何做到。如果有人可以给我一些指导,我将不胜感激!谢谢!
RatingSchema.statics.getPostRating = function(post, callback)
{
this.count({ post: post, positiveReview: true }, function(err, posCount){
if(err)
{
callback(err);
return;
}
this.count({ post: , positiveReview: false }, function(err, negCount){
if(err)
{
callback(err);
return
}
callback(err, posCount, negCount)
}
}
最佳答案
如前所述,您可以使用聚合框架在一个实际的查询中执行此操作,根据您的需要,甚至可以通过几种方法来实现该结果。但是实际上,作为一个通用方法,关于.count()
的性能存在一些问题,最好通过示例来说明。
首先,为了方便起见,我将在外壳中设置一些数据:
var bulk = db.testcol.initializeOrderedBulkOp();
for ( var x=1; x <= 100000; x++ ) {
bulk.insert({ value: Math.floor(Math.random(2)*2) });
if ( x % 1000 == 0 ) {
bulk.execute();
bulk = db.testcol.initializeOrderedBulkOp();
}
}
var async = require('async'),
mongoose = require('mongoose'),
Schema = mongoose.Schema;
var testSchema = new Schema({
value: Number
});
mongoose.connect('mongodb://localhost/test');
var Test = mongoose.model( 'Test', testSchema, 'testcol' );
async.series(
[
// Time aggregation two results
function(callback) {
var start = new Date();
Test.aggregate(
[{ "$group": { "_id": "$value", "count": { "$sum": 1 } } }],
function(err,result) {
var obj = {
"start": start,
"end": new Date()
};
obj.time = obj.end.valueOf() - obj.start.valueOf();
obj.result = result;
callback(err,obj);
}
);
},
// Time aggregation conditional
function(callback) {
var start = new Date();
Test.aggregate(
[
{ "$group": {
"_id": null,
"positive": {
"$sum": {
"$cond": [
{ "$eq": [ "$value", 1 ] },
1,
0
]
}
},
"negative": {
"$sum": {
"$cond": [
{ "$eq": [ "$value", 0 ] },
1,
0
]
}
}
}}
],
function(err,result) {
var obj = {
"start": start,
"end": new Date()
};
obj.time = obj.end.valueOf() - obj.start.valueOf();
obj.result = result;
callback(err,obj);
}
);
},
// Time query parallel
function(callback) {
var start = new Date();
async.parallel(
[
function(callback) {
Test.count({ value: 1 },callback);
},
function(callback) {
Test.count({ value: 0 },callback);
}
],
function(err,results) {
var obj = {
"start": start,
"end": new Date()
};
obj.time = obj.end.valueOf() - obj.start.valueOf();
obj.result = results;
callback(err,obj);
}
);
}
],
function(err,results) {
if (err) throw err;
console.log( JSON.stringify( results, undefined, 2 ) );
}
);
[
{
"start": "2014-10-01T08:18:28.059Z",
"end": "2014-10-01T08:18:28.263Z",
"time": 204,
"result": [
{
"_id": 1,
"count": 49965
},
{
"_id": 0,
"count": 50035
}
]
},
{
"start": "2014-10-01T08:18:28.264Z",
"end": "2014-10-01T08:18:28.404Z",
"time": 140,
"result": [
{
"_id": null,
"positive": 49965,
"negative": 50035
}
]
},
{
"start": "2014-10-01T08:18:28.405Z",
"end": "2014-10-01T08:18:28.491Z",
"time": 86,
"result": [
49965,
50035
]
}
]
1
或
0
,但是您可以看到此时间为204ms。
$cond
运算符,以便将每个结果“拆分”为一个文档中自己的属性。此处花费的时间明显少于140ms。
$group
期间的实现方式却截然不同。这在两种聚合方法之间的性能差异中部分可见,但是主要的事情是基本的“查询引擎”以更有效的方式“计数”事物。
true/false
匹配,在该属性上建立索引甚至还会产生“更快”的结果。
true/false
是一个好例子),那么性能最高的选项是运行“并行查询”,如下所示:已在此示例中显示。性能提高通常是您要“计数”的不同属性值数量的一个因素。
.count()
语句相结合,然后确保您等待组合的结果,从而为此类操作提供了最佳性能结果。一般而言,对于基本计数以外的任何内容都不是正确的,但这完全取决于您实际尝试执行的操作。
关于javascript - 如何在 Mongoose 中为同一字段返回多个计数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26135949/
当我保存4条记录时,我需要将它们一一保存,所以我的代码是 a.save(function(){ b.save(function(){ c.save(function(){ d.save(f
Mongoose在版本4.2.7中创建了一个新的单个子文档功能(documentation和feature request),允许使用单个嵌入式子文档架构,其行为方式与一对多子文档的行为相同。 在父级
Mongoose 版本 >= 4.0 有一个时间戳选项,当 timestamps 设置为 时,该选项会为架构创建 updatedAt 和 createdAt 字段正确。 http://mongoose
我注意到某些图书馆喜欢 mock 鹅 ( https://github.com/mccormicka/Mockgoose/blob/master/test/index.spec.js ) 使用 req
我正在与 Mongoose 合作。我见过很多开发者发出以下命令: mongoose.Promise = global.Promise; 然后我很好奇 mongoose.Promise 的原始值是什么。
当我运行与数据库大量连接和断开连接的测试时,我收到以下警告。 (node) warning: possible EventEmitter memory leak detected. 11 connec
我可以在 Mongoose 的子文档数组中填充动态引用(使用“refPath”)虚拟字段吗? 数据结构如下 Group - Members -> User 代码:模型/模式 let MemberSc
我正在我的应用程序中做一些测试,看看内存缓存是否真的在工作。但是,由于 memory-cache 显然没有公开“命中”事件,我无法判断是否真的从缓存中获取数据。所以我试着看看当应用程序实际从数据库中获
我是 nestjs 的新手。我使用 @nestjs/mongoose,我需要在我的类模式中引用嵌套对象中的几个字段,但我不知道该怎么做。 dietDays 对象必须包含一个日期字段和包含对 Meal
我是 mongodb 的新手,我有一个这样的数据模型 { last_updated: Date.now(), csgo_items:[ {name: 'name', p
这是我的方案: var documentSchema = mongoose.Schema({ 'facts': [{ 'type': { type: String, requi
我想删除多个 _ids = ['123', '234', '345']; _ids.forEach(_id => { await model.deleteOne({ _id }); }); 有没有
我有一个像这样的 Mongoose 模式: var Address = { doorNo:String, city:String, state:String, coun
我的文档包含一个名为 clients 的字段那应该包含一组客户端ID。 { "first_name":"Nick", "last_name":"Parsons", "email":"nic
我遇到了以下我无法理解的代码行,尽管有很多教程提供了与 populate 的示例相关的信息。但没有一个能解释它究竟意味着什么。这是一个例子 var mongoose = require('mongoo
我有一个具有多个唯一性的架构,如下所示: var userSchema = new mongoose.Schema({ user: { type: String, unique:
我有一个 Mongoose 模式,其中有 4 个子模式。我一直在关注这里的文档https://github.com/LearnBoost/mongoose关于嵌入文档 var scenarios =
我希望每个字符串属性都默认设置为 true。有办法吗? ?? mongoose.Schema.String -> default { trim: true } var schema = new Sch
我有这个代码 var ClientSchema = new Schema({ name: {type: String, required: true, trim: true} }); var Cl
许多教程告诉您在您的 userSchema 页面中使用 bycrypt。保存新用户后,它会附带加密密码。伟大的。然而,我想,当我用某些东西编辑用户时,它也会重新哈希密码,导致无法登录。你能给我一个解决
我是一名优秀的程序员,十分优秀!