4

次の2つのスキーマとモデルがあります。

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

1 に答える 1

6

あなたはあなたの中に物事を逆行させています$pull。代わりにこれを試してください:

CustomerModel.update({_id: job.customer}, {$pull : {jobs : job._id}}, ...
于 2013-01-23T23:03:56.097 に答える