2013-01-23 192 views
3

刪除我有以下兩個模式和模型:貓鼬從嵌套文檔

var Customer = new Schema({ 
    name: String, 
    jobs: [{ type: Schema.Types.ObjectId, ref: 'Job' }] 
}); 

var Job = new Schema({ 
    title: String, 
    customer: { type: Schema.Types.ObjectId, ref: 'Customer' } 
}); 

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

工作文件必須通過_id一個參考客戶的文檔和客戶文件還包含了所有的工作_id的數組。

當我刪除作業時,我需要從Customer.jobs數組中刪除相應的_id。

這裏是我的路線 - 作業被刪除,但我不能從陣列中取出的ID

app.delete('/api/jobs/:jobId', function(req, res){ 
    return JobModel.findById(req.params.jobId, function(err, job){ 
     return job.remove(function(err){ 
      if(!err){ 
       CustomerModel.update({_id: job.customer._id}, {$pull : {'customer.jobs' : job.customer._id}}, function(err, numberAffected){ 
         console.log(numberAffected); 
         if(!err){ 
          return console.log('removed job id'); 
         } else { 
          return console.log(err); 
         } 
        }); 
       console.log('Job removed'); 
       return res.send(''); 
      } else{ 
       console.log(err); 
      } 
     }); 
    }); 
}); 

numberAffected始終爲0和「刪除作業ID」永遠開除

回答

4

你」我在你的$pull後退了。試試這個:

CustomerModel.update({_id: job.customer}, {$pull : {jobs : job._id}}, ... 
+0

這還是沒有numberAffected = 0 –

+0

@ jamieholliday查看更新的答案。 'job.customer'直接包含客戶'_id',因爲你沒有填充它。 – JohnnyHK