使用Mongoose的嵌套模式的CRUD

时间:2015-01-12 20:13:37

标签: node.js mongoose crud

我正在尝试使用Mongoose为mongodb子文档设置带有CRUD的nodejs应用程序,但无法弄清楚如何访问嵌套对象的_id。我只能得到父ObjectId。我可以对新的子对象执行.push,但不能对现有的子对象执行简单的get,put或delete。

这是我的架构:

//new user model

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

// Task schema
var taskSchema = mongoose.Schema({
        clientEasyTask             : { type: String },
        clientHardTask         : { type: String },
        clientStupidTask      : { type: String }
});

var userSchema = new mongoose.Schema({
  email: { type: String, unique: true, lowercase: true },
  password: String,

  task             : [taskSchema]
});

module.exports = mongoose.model('Task', taskSchema);
module.exports = mongoose.model('User', userSchema);

这是我的路线:

'use strict';

var isAuthenticated = require('./middleware/auth').isAuthenticated,
isUnauthenticated = require('./middleware/auth').isUnauthenticated;

var User            = require('./models/user');
var Task            = require('./models/user');

// Create user.task

module.exports = function (app, passport) {

  app.post('/api/tasks', isAuthenticated, function (req, res) {

    var userEmail = req.body.email;
    var easyTask = req.body.easyTask;

    User.findOne({ 'email' :  userEmail }, function(err, user) {
      console.log('found user and defining status and data');
      var status;
      var data;

      if (err) {
        status = 'error';
        data = 'unknown error occurred';
      }
      if (user === null) {
        status = 'error';
        data = 'user not found';
      } else {
        status = 'ok';
        data = user;
      }

      user.task.push({
        clientEasyTask: easyTask
      });

      user.save();

      res.json({
        response: {
          'status': status
        }
      });
    });
  });


// Get one user.task
  app.get('/api/tasks/:id', function (req, res) {
      return Task.findById(req.params.id, function(err, task) {

      if(!task) {
        res.statusCode = 404;
        return res.send({ error: 'Not found' });
      }

      if(!err) {
        return res.send({ status: 'OK', task:task });
      } else {

        res.statusCode = 500;
        console.log('Internal error(%d): %s', res.statusCode, err.message);
        return res.send({ error: 'Server error' });
      }
    });
  });
};

我正在使用Postman测试所有内容,因此没有前端代码。当我传递任务的_id(嵌套在用户中)时,当我调用Get on'/ api / tasks /:id'时,我收到null。我怎样才能获得特定任务?

mongoose文档说明你可以使用parent.children.id(id);但我无法让它发挥作用。

1 个答案:

答案 0 :(得分:1)

task User字段包含作为嵌入式子网的任务,而不是对其他集合的引用,因此您无法独立于用户查询任务(就像您尝试的那样)做)。

要查询嵌入式任务subdoc,可以使用如下查询:

User.findOne({'task._id': req.params.id})
  .select('task.$') // Just include the matching task element
  .exec(function(err, user) {
    if(!user) {
      res.statusCode = 404;
      return res.send({ error: 'Not found' });
    }
    if(!err) {
      // The matching task will always be in the first element of the task array
      return res.send({ status: 'OK', task: user.task[0] });
    } else {
      res.statusCode = 500;
      console.log('Internal error(%d): %s', res.statusCode, err.message);
      return res.send({ error: 'Server error' });
    }
  }
);

为了提高效率,您需要在{'task._id': 1}上添加索引。