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」永遠開除
這還是沒有numberAffected = 0 –
@ jamieholliday查看更新的答案。 'job.customer'直接包含客戶'_id',因爲你沒有填充它。 – JohnnyHK