首页 文章

使用nodejs在mongoose模式中的数组中添加值

提问于
浏览
0

我正在开发一个在线课程申请表 . 我已经为课程注册创建了一个集合,我将存储课程名称和在该课程中注册的用户 . Mongoose模式看起来像这样 . 它的名字是courseEnrollment.js .

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

var courseEnrollment = new Schema({


courseEnrolled: [{courseName : String},
                 {username : [{user : String}]}
                ]

}, {collection : 'courseEnrollment'});

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

当用户点击注册时,GET请求将转到'localhost:3000 / learn /:courseName / enroll' . 在该路由处理程序中,我将用户课程注册信息存储在两个不同的集合中 . 1)在课程集中,我在上面展示了 . 2)在存储用户名,密码等的用户帐户信息中,我还存储用户注册的课程 .

现在我面临的问题是,它只更新了User集合,而不是出于某种原因而更新了courseEnrollment集合 . 它给出了以下错误 .

events.js:141
  throw er; // Unhandled 'error' event
  ^

TypeError: Cannot read property 'push' of undefined
at /home/mobileedx/WebstormProjects/passportAuthentication/routes/index.js:387:47
at Query.<anonymous> (/home/mobileedx/WebstormProjects/passportAuthentication/node_modules/mongoose/lib/model.js:3340:16)
at /home/mobileedx/WebstormProjects/passportAuthentication/node_modules/mongoose/node_modules/kareem/index.js:259:21
at /home/mobileedx/WebstormProjects/passportAuthentication/node_modules/mongoose/node_modules/kareem/index.js:127:16
at nextTickCallbackWith0Args (node.js:420:9)
at process._tickCallback (node.js:349:13)

这是我在'localhost:3000 / learn /:courseName / enroll'的路由处理程序中的代码

/**
  * Here If a user clicks on enroll, then the GET request will come on this page. If user is not authenticated then it
 * will redirect to the login page. If user is logged in then, user will get the courseHome page.
 */

 router.get('/learn/:courseName/enroll', isAuthenticated, function (req, res) {

  var user = req.user.username;
  var course = req.params.courseName;

  console.log('user trying to enroll is: ' + user);
  console.log('coursename user is trying to enroll is: ' + course);

  courseEnrollment.findOne({ 'courseEnrolled.courseName' :  req.params.courseName }, function(err, courseEnroll) {
      // In case of any error, return using the done method
      if (err) {
          console.log('Error in SignUp: ' + err);
          return done(err);
      }
      console.log('courseEnroll value is: ' + courseEnroll);

      courseEnroll.courseEnrolled.username.push({ "user": req.user.username});

      courseEnroll.save(function (err, data) {
          if (err)
              throw err;
          else {
              console.log('course Updated in courseEnrollment collection');
          }
      });
  });


  // When a user clicks on 'enroll' to enroll to a course, then the course name should be added in the
  // user's courseEnrolled list as well. This is what we are doing here.


  User.findOne({ 'username' :  req.user.username }, function(err, user) {
      // In case of any error, return using the done method
      if (err) {
          console.log('Error in SignUp: ' + err);
          return done(err);
      }
      console.log('user value is: ' + user);
      console.log('username value is: ' + user.username);
      user.courseEnrolled.push({ "courseName": course});

      user.save(function (err, data) {
          if (err)
              throw err;
          else {
              console.log('course Updated in user account collection');
          }
      });

      res.render('home', {user: req.user});
  });
});

请让我知道,我在这里出错了 . 我可以使用mongoose填充来填充courseEnrollment集合中用户集合的用户名字段中的用户名 . 如果是的话,那该怎么办呢 . 谢谢 .

1 回答

  • 1

    根据我的猜测,架构存在问题 . 你的课程注册模式 . 应该如下 . 每个课程包含一个对象的数组 . 其中包含有关其名称和在其中注册的用户的信息 .

    courseEnrolled: [{
               courseName : String,
               username : [{user : String}]
        }]
    

    希望能帮助到你 .

    .................................................

    好的,如果这只是维护加入特定课程的用户的模式 . 然后,您可以遵循以下架构

    var courseEnrollment = new Schema({
       courseName : String:,
       usersEnrolled : [String]
    }, {collection : 'courseEnrollment'});
    

    它可以在这样的查询中访问 .

    courseEnrollment.findOne({ 'courseName' :  req.params.courseName }, function(err, courseEnroll) {
      // In case of any error, return using the done method
      if (err) {
          console.log('Error in SignUp: ' + err);
          return done(err);
      }
      console.log('courseEnroll value is: ' + courseEnroll);
    
      courseEnroll.username.push({ "user": req.user.username});
    
      courseEnroll.save(function (err, data) {
          if (err)
              throw err;
          else {
              console.log('course Updated in courseEnrollment collection');
          }
      });
    

    });

相关问题