【发布时间】:2017-07-06 22:10:47
【问题描述】:
这是我的recipe.js 文件...
const express = require('express');
const mongoose = require('mongoose');
const User = require('../model/user');
require('mongoose-currency').loadType(mongoose);
const Currency = mongoose.Types.Currency;
const Schema = mongoose.Schema;
const reviewSchema = require('../model/review');
let recipeSchema = new Schema({
name: {
type: String,
required: true
},
description: {
type: String,
},
steps: {
type: String,
required: true,
},
ingredients: {
type: Array,
default: ['1', '2', '3', '4']
},
category: {
type: String,
required: true,
index: true
},
postedBy: {
type: String,
required: true,
},
reviewsOfRecipe: [reviewSchema],
numberOfRatings: {
type: Number,
default: 0
},
totalAddedRatings: {
type: Number,
default: 0
},
reviewAverage: {
type: Number,
default: 0
},
postersCreationDate: {
type: Number,
index: true
},
likedBy: {
type: Array
},
reviewedBy: {
type: Array
}
});
// Here is my static method
recipeSchema.methods.calculateAverage = function(){
let recipe = this;
if (recipe.numberOfRatings === 0 && recipe.totalAddedRatings === 0){
recipe.reviewAverage = 0;
}
else {
recipe.reviewAverage = recipe.totalAddedRatings / recipe.numberOfRatings
}
};
let Recipe = mongoose.model('Recipe', recipeSchema);
module.exports = Recipe;
在我的路由器文件中,每次用户提交对食谱的评论时,numberOfRatings 和 totalAddedRatings 字段都会增加。在它们增加后,我的静态方法calculateAverage 应该运行并更新文档。
这是我的代码中的样子:
Recipe.findOneAndUpdate({_id: recipe._id, postersCreationDate: recipe.postersCreationDate},{$inc: {numberOfRatings: 1, totalAddedRatings: reviewScore}}, {returnNewDocument: true}).then((recipe) => {
recipe.calculateAverage();
});
但是,每次用户提交评论时,虽然 numberOfRatings 和 numberOfRatings 会相应增加,但 reviewAverage 不会。
我正在考虑将reviewAverage 设置为虚拟字段;但我担心这样做会使按照最高和最低评论平均数对食谱进行排序变得更加困难和低效。
【问题讨论】:
标签: javascript node.js mongodb mongoose mongoose-schema