繁体   English   中英

ZCCADCDEDB567ABAE643E15DCF0974E503Z 一对多不起作用(Nodejs)

[英]Mongoose one-to-many not working (Nodejs)

我创建了 2 个用户(管理员和用户),并且我为一个用户创建了许多 ToDos,但是我的 Todo 数组在我的用户架构中是空的。 无法理解为什么 todo 任务没有分配给用户架构。

用户模式

var userSchema = new Schema({
    name: {
        type: String,
        required: true,
        maxlength: 30,
        trim: true
    },    
    role: {
        type: Number,
        default: 0
    },
    todos: [{
        type: Schema.Types.ObjectId,
        ref:"Todo"
    }]
});
module.exports = mongoose.model("User", userSchema)

待办事项模式

let Todo = new Schema({
    todo_heading: {
        type: String
    },
    todo_desc: {
        type: String
    },
    todo_priority: {
        type: String
    },
    todo_completed: {
        type: Boolean
    },
    user: {
        type: Schema.Types.ObjectId,
        ref:"User"
    }

})

module.exports = mongoose.model('Todo', Todo);

这是我的路线

用户路线

router.get("/user/:userId/todos", isSignedIn, isAuthenticated, getToDos)

都都路线

router.get("/", getTodos)
router.get("/:id", getUsertodos);
router.post("/user/:userId/add", addUsertodos);

用户控制器

exports.getToDos = (req, res) => {
    User.find({ _id: req.params._id })
        .populate("todos")
        .exec((err, toDo) => {
            if (err) {
                res.json(err)
            }
            res.json(toDo)
        })
}

待办事项控制器

exports.addUsertodos = (req, res) => {

    let todo = new Todo(req.body)
    todo.save((err, todo) => {
        if (err) {
            return res.status(400).json({
                error: "not saved"
            })
        }
        else {
            return res.json(todo)
        }
    })
}

在此处输入图像描述

如果在创建用户时将新创建的 todo 的 objectId 添加到 todos 属性,它应该可以按预期工作。

   //routers/todo.js
    var express = require('express');
    var router = express.Router();
    const Todo = require('../models/Todo');
    const User = require('../models/User');
    
    /* GET home page. */
    router.get('/', async function (req, res) {
      let todos = await Todo.find();
      res.json({
        todos
      });
    });
    
    router.post('/todos', async function (req, res) {
      //add todos
      let {
        todo_desc,
        todo_heading,
        todo_priority,
        todo_completed
      } = req.body;
      try {
        //NOTE: for simplicity assigning first user but you can grab it from the params
        let user = await User.findOne();
        let todo = await Todo.create({
          todo_desc,
          todo_completed,
          todo_priority,
          todo_heading,
          user: user._id
        })
        res.json({
          message: 'todo created successfully',
          todo
        });
      } catch (err) {
        return res.status(500).json({
          message: 'Unable to create a todo',
          err: JSON.stringify(err)
        })
      }
    
    });
    
    module.exports = router; 

这是用户路由,其中 post 路由获取创建 ID 的字符串 id 并将其转换为 ObjectId(),将其分配给 todos。

var express = require('express');
var router = express.Router();
let _ = require('lodash');
var mongoose = require('mongoose');


const User = require('../models/User');
/* GET users listing. */


router.post("/", async function (req, res) {
  let {
    name,
    todos
  } = req.body;

  try {
    let user = new User();
    user.name = name;
    let objectIds = todos.split(',').map(id => mongoose.Types.ObjectId(id));
    user.todos.push(...objectIds)
    await user.save()
    console.log("user: ", JSON.stringify(user));
    if (_.isEmpty(user)) {
      res.status(500).json({
        message: 'unable to create user'
      })
    }
    res.json(user);
  } catch (err) {
    res.status(500).json({
      message: 'unable to create user',
      err: JSON.stringify(err)
    })
  }
});

router.get("/", async function (req, res) {
  try {
    let user = await User.find().populate('todos');
    console.log("user: ", JSON.stringify(user));
    if (_.isEmpty(user)) {
      res.status(500).json({
        message: 'unable to find user'
      })
    }
    res.json(user);
  } catch (err) {
    res.status(500).json({
      message: 'unable to find user',
      err: JSON.stringify(err)
    })
  }
});

module.exports = router;

查看随附的屏幕截图,用户记录现在包含分配给它的待办事项。

填充待办事项

如果你想检查工作代码,请访问我创建的这个repo 。!。

希望这有帮助。干杯!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM