gpt4 book ai didi

javascript - 如何在MongoDB中存储和区分数据?

转载 作者:可可西里 更新时间:2023-11-01 10:45:15 25 4
gpt4 key购买 nike

请注意我是一名新程序员。

我不知道如何在 Mongo 中有效地记录数据,因此我可以重新使用它并随着时间的推移进行比较。

我正在构建一个管理仪表板,我在其中从 HTML 收集数据并将其存储在 Mongo 集合和定义的架构中。数据被转换成图形供用户查看。

现在,我正在收集今年的数据。明年,我将收集完全相同或几乎完全相同的数据。

然后我想创建比较。

我最初想创建几个模型来区分。

所以从我下面的代码:

今年的模型是 2019manageSchema....明年的模型将是 2020manageSchema ...但模式与我收集相同数据的模式完全相同。

但我认为这不是最佳做法。

此外,我在考虑路线,要求所有的 mdoel 并通过每条路线传递它们会很困惑。

模式

var mongoose = require("mongoose"),
math = require('mathjs');

*****DATABASE CONFIG*******
var manageSchema = new mongoose.Schema({
period: String,
managers: Number,
staffs: Number,
staffcosts: Number,
headcountavg: Number,
frontliners: Number,
supportfunc: Number,
depthratio: Number,
totalrevenue: Number,
grossprofit: Number,
noofworkdays: Number,
sickleavestaken: Number,
unauthleavestaken: Number,
authleavestaken: Number,
eesmanagerscoreprev: Number,
eesmanagerscore: Number,
eesrecognitionscoreprev: Number,
eesrecognitionscore: Number,
created: {type: Date, default: Date.now},
user: {
id: {
type: mongoose.Schema.Types.ObjectId,
ref: "User"
},
username: String
}
});

module.exports = mongoose.model("Manage", manageSchema);

路线:


var express = require("express");
var router = express.Router();
var User = require("../models/user");
var Manage = require ("../models/manages");

//Manage
//Index Route for manage - view graphs + edit

router.get("/manage", isLoggedIn, function(req, res){
Manage.find({}, function(err, manages){
if(err){
console.log("ERROR");
} else {
res.render("manage", {manages: manages});
}
});
});

//NEW ROUTE - sends to forms page for Manage
router.get("/manage/new_admin0", isLoggedIn, function(req, res){
res.render("manageForm");
});


//CREATE ROUTE - POST request to manage
router.post("/manage", isLoggedIn, function (req, res){
//create demog
Manage.create(req.body.manage, function(err, newManage){
if(err){
console.log(err);
} else {
//add username and id to recruit
newManage.user.id = req.user._id;
newManage.user.username = req.user.username;
//save recruit
newManage.save();
//redirect
console.log(newManage);
res.redirect("/manage");
}
});
});

//SHOW ROUTE - Specific info
router.get ("/manage/:id", checkOwnership, function(req, res){
Manage.findById(req.params.id, function(err, foundManage){
if(err){
res.redirect("back");
} else {
res.render("showmanage", {manages: foundManage});
}
});
});

// EDIT ROUTE - form to update existing data
router.get("/manage/:id/edit", checkOwnership, function(req, res){
Manage.findById(req.params.id, function(err, foundManage){
res.render("editmanage", {manages: foundManage});
});
});

//UPDATE ROUTE - use edit form info and update existing data
router.put("/manage/:id", checkOwnership, function(req, res){
Manage.findByIdAndUpdate(req.params.id, req.body.manage, function(err, updateManage){
if(err){
res.redirect("back");
} else {
res.redirect("/manage/" + req.params.id);
}
});
});


//middleware
function isLoggedIn(req, res, next){
if(req.isAuthenticated()){
return next();
}
res.redirect("/login");
}

function checkOwnership(req, res, next) {
if(req.isAuthenticated()){
Manage.findById(req.params.id, function(err, foundManage){
if(err){
res.redirect("back");
} else {
//check if user own data
if(foundManage.user.id.equals(req.user._id)){
next();
} else {
res.redirect("back");
}
}
});
} else {
res.redirect("back");
}
}

module.exports = router;

请帮助存储,最好是如何在不影响当前路由的情况下进行存储。

最佳答案

您可以使用 MongoDB 根据日期对数据进行分组聚合管道运算符,例如 $year$month$week

{
$project: {
month: { $month: "$created" },
year: { $year: "$created" },
}
},
{
$group: {
_id: {
year: '$year',
month: '$month'
},
count: {
$sum: 1
}
}
}

查看下面的引用链接,这将帮助您构建查询,

关于javascript - 如何在MongoDB中存储和区分数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54456144/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com