尝试更新父文档猫鼬中的子文档

时间:2019-10-31 13:39:02

标签: node.js mongodb express mongoose

我正在尝试使用猫鼬更新或删除父文档中的子文档。

我的代码:

editSubscription(req, res) {
    const token = req.headers.authorization;
    jwt.verify(token, req.app.get('yourSecretKey'), function (err, payload) {
        userModel.update({ _id: payload.user._id, "subscriptions._id": req.params.id }, { "$set": { "subscriptions.$": req.body } }, function (err, obj) {
           console.log(obj)
       })
    })
}

console.log的输出是

{ n: 0, nModified: 0, ok: 1 }

我应该怎么做?我知道它的修改过的nModified是否返回1。我找不到任何有关如何解决或解决它的文档,以及我已经尝试过的关于stackoverflow的所有解决方案,都没有用。

我的收藏夹中的文档样本:

id: '5db990daa05aa90de0c8b86b',
user:
{ role: 'User',
 subscriptions: [ 
  { active: true,
_id: '5dbad05aaf232e2bdc033339',
name: 'Basic Fit',
price: 20,
paymentDate: '07-11-2020',
created: '2019-10-31T12:15:22.360Z',
updated: '2019-10-31T12:15:22.360Z' },
{ active: true,
_id: '5dbad2568bf56255a0f39bc7',
name: 'Netflix',
price: 10,
paymentDate: '07-11-2019',
created: '2019-10-31T12:23:50.141Z',
updated: '2019-10-31T12:23:50.141Z' } ]
  ],
 _id: '5db990daa05aa90de0c8b86b',
 fullname: 'Test naam',
 email: 'test1@mail.com',
 password:
  '$2a$10$VzBnIcVraIRdmzy6rPHOX.7gGOXToTBNISLEfi429OfpRx02FxCaO',
 birthDate: '02-12-1988',
 created: '2019-10-30T13:32:10.276Z',
 updated: '2019-10-30T13:32:10.276Z',
 __v: 0 },

payload.user._id ==已验证的登录用户ID

req.params.id应该是尝试编辑的subscriptionId

1 个答案:

答案 0 :(得分:0)

尝试一下:

editSubscription(req, res) {
    const token = req.headers.authorization;
    jwt.verify(token, req.app.get('yourSecretKey'), function (err, payload) {
        userModel.update({ _id: ObjectId(payload.user._id), "subscriptions._id": ObjectId(req.params.id) }, { "$set": { "subscriptions.$": req.body } }, function (err, obj) {
           console.log(obj)
       })
    })
}