mongoose从嵌套文档中删除

4

我有以下两个模式和模型:

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,而“removed job id”始终会被触发。

1个回答

6
您在$pull中的操作顺序有误,请尝试使用以下顺序进行操作:
CustomerModel.update({_id: job.customer}, {$pull : {jobs : job._id}}, ...

仍然返回没有受影响的数字 numberAffected = 0。 - jamie holliday
@jamieholliday 请查看更新后的答案。由于您没有填充,因此job.customer直接包含客户端_id - JohnnyHK

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接