猫鼬嵌套文件

jam*_*day 2 mongoose node.js

我在mongoose中设置了两个模式:

var Job = new mongoose.Schema({
    title: String,
    budget: Number
});

var JobModel = mongoose.model('Job', Job);

var Customer = new mongoose.Schema({
    name: String,
    jobs: [Job]
});

var CustomerModel = mongoose.model('Customer', Customer);
Run Code Online (Sandbox Code Playgroud)

Customer模型具有一系列作业模型.

我正在添加一项新工作如下:

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

    var job = new JobModel({
        title: req.body.title,
        budget: req.body.budget
    });

    job.save(function(err){
        if(!err){
            CustomerModel.findById(req.body.customerId, function(err, customer){
                if(!err){
                    customer.jobs.push(job);
                    customer.save(function(err){
                        if(!err){
                            return console.log('saved job to customer');
                        }
                    });
                }
            });
            return console.log('created job');

        } else {
            return console.log(err);
        }
    });

    return res.send(job);
});
Run Code Online (Sandbox Code Playgroud)

当我添加一份新工作并获得我认为正确的所有客户时:

[{
    "__v": 1,
    "_id": "50f85695771aeeda08000001",
    "name": "Customer1",
    "jobs": [
      {
        "_id": "50fad6985edd968840000002",
        "budget": 100,
        "title": "job1"
      }
    ]
  }, ...]
Run Code Online (Sandbox Code Playgroud)

现在,如果我更新job1并获取所有作业,则作业1已更新(预算现在为500)

[{
    "title": "job1",
    "budget": 500,
    "_id": "50fad6985edd968840000002",
    "__v": 0
  }, ...]
Run Code Online (Sandbox Code Playgroud)

但是客户工作数组中的job1保持不变.

 [{
        "__v": 1,
        "_id": "50f85695771aeeda08000001",
        "name": "Customer1",
        "jobs": [
          {
            "_id": "50fad6985edd968840000002",
            "budget": 100,
            "title": "job1"
          }
        ]
      }, ...]
Run Code Online (Sandbox Code Playgroud)

因此,我是否需要搜索Customer1的作业数组并找到job1作业并在每次更新或删除时更新该作业,或者我是否完全以错误的方式完成整个嵌套操作?

我得知客户中的jobs数组是一个对象数组,但我认为它们可能只是作业的参考副本而不是重复?

Joh*_*yHK 15

如果您使用嵌入式Job文档阵列,则它们是完全独立的副本,您可以将它们与单独的jobs集合保持同步.

另一种方法是让jobs字段Customer包含一个ObjectId引用数组,'Job'然后根据需要使用Mongoose的查询填充按需填充它们.

jobs: [{type: Schema.Types.ObjectId, ref: 'Job'}]
Run Code Online (Sandbox Code Playgroud)