创建包含带有猫鼬细分的文档

发布于 2025-02-03 02:28:03 字数 1641 浏览 3 评论 0原文

我正在尝试创建我的MongoDB Atlas数据库,但是子记录值没有通过。我应该以某种方式循环吗?找不到任何解决方案。谢谢

Postman请求:

{
    "name" : "New Avengers",
    "items": [
        {"itemName": "Iron Man"},
        {"itemName": "Thor"}
    ],
    "tasks": [
        {"taskName": "Call Avengers"},
        {"taskName": "Watch out for Loki"}
    ]
}

数据库记录:

数据库记录img

model-> project.model.js


const { Schema, default: mongoose, mongo } = require('mongoose');

const itemsSchema = new Schema({
    itemName: String,
    mainItem: { type: Boolean, default: false }
})

const tasksSchema = new Schema({
    taskName: String,
    columnLabel1: String,
    columnLabel2: String,
})

const projectSchema = new Schema({
    name: {
        type: String,
        required: [true, 'Title is required!'],
        unique: true
    },
    items: [itemsSchema],
    tasks: [tasksSchema]

},{
    timestamps: true
});

const Project = mongoose.model("Project", projectSchema);
module.exports = Project; 

路线 - > project.js

const router = require('express').Router();
let Project = require('../models/project.model');

// Create new Project
router.route('/add').post( async (req, res) => {
    const newProject = new Project({
        name: req.body.name,
        items: [{itemName: req.body.itemName}],
        tasks: [{taskName: req.body.taskName}]
    });

    try {
        await newProject.save();
    } catch(err) {
        res.status(400).json(err);
    }
});

module.exports = router;

I am trying to create my MongoDB Atlas database but the subdocument values are not coming through. Am i supposed to loop through them somehow ? Can't find any solutions. Thanks

Postman request:

{
    "name" : "New Avengers",
    "items": [
        {"itemName": "Iron Man"},
        {"itemName": "Thor"}
    ],
    "tasks": [
        {"taskName": "Call Avengers"},
        {"taskName": "Watch out for Loki"}
    ]
}

Database Record :

database record img

Model-> project.model.js


const { Schema, default: mongoose, mongo } = require('mongoose');

const itemsSchema = new Schema({
    itemName: String,
    mainItem: { type: Boolean, default: false }
})

const tasksSchema = new Schema({
    taskName: String,
    columnLabel1: String,
    columnLabel2: String,
})

const projectSchema = new Schema({
    name: {
        type: String,
        required: [true, 'Title is required!'],
        unique: true
    },
    items: [itemsSchema],
    tasks: [tasksSchema]

},{
    timestamps: true
});

const Project = mongoose.model("Project", projectSchema);
module.exports = Project; 

Route -> project.js

const router = require('express').Router();
let Project = require('../models/project.model');

// Create new Project
router.route('/add').post( async (req, res) => {
    const newProject = new Project({
        name: req.body.name,
        items: [{itemName: req.body.itemName}],
        tasks: [{taskName: req.body.taskName}]
    });

    try {
        await newProject.save();
    } catch(err) {
        res.status(400).json(err);
    }
});

module.exports = router;

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

东风软 2025-02-10 02:28:03

从请求对象中,没有tasknameitemName字段。 newProject变量应为:

const newProject = new Project({
    name: req.body.name,
    items: req.body.items,
    tasks: req.body.tasks
});

哪个项目任务是从req.body收到的数组。

From the request object, there are no taskName and itemName fields. The newProject variable should be:

const newProject = new Project({
    name: req.body.name,
    items: req.body.items,
    tasks: req.body.tasks
});

which items and tasks are the arrays received from the req.body.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文