簡體   English   中英

無法使用貓鼬更新子文檔

[英]Can't update subdocuments with mongoose

當我嘗試使用 mongoose 從子文檔更新數據時遇到問題

這是數據模型:

{ status: 'regular',
  devices:
   [ { ip: 'deviceIp',
       active: true,
       _id: 5f4c05cb4708cf0e37a68ac0,
       name: 'deviceName',
       os: 'deviceOs',
       refreshToken:
        'eyJhbGciOiJSUzUxMiIsInR5cCI6IkpXVCIsImtpZCI6IjEifQ.eyJ1c2VyIjoidGVzdFVzZXIiLCJtYWlsIjoidGVzdEB1c2VyLmNvbSIsImlhdCI6MTU5ODgxNzczOSwibmJmIjoxNTk4ODE3NzQxLCJleHAiOjE2MDE0MDk3MzksImF1ZCI6Im15YXVkIiwiaXNzIjoibXlpc3N1ZXIiLCJzdWIiOiJ2IiwianRpIjoiMSJ9.di6BeKZV5OufLEY8Hnk_nC_vcCsVZZ_XJecUc1h695hDbFlgxTtNOZoi-e3uvAkckclfAKjJk7T-osEGohsnfpdA07XDH3pOniGYHVw_k1u-e6-0pu9YpSop6cv7cnlsR-50QjE9vmzg4F1mBy2ZYVCp6GSfg46duXjStUOamUM30AYElSSVX5EMsK1uBg2tfVipV8xRhHCZIIdYNr-xq8G5CcZ1lEIQrtkC2ljU7roLpC5pejZ-JkaHSNNKwVARW7JuLNbb4FaSAjv_AE87faozPWAbdgXIaap8A5nLeH_-XJhwJDIIRGnwwsJM969DaTVee2F40lUfBzhugmffeg',
       loginDate: 2020-08-30T20:02:19.257Z } ],
  _id: 5f4c05c64708cf0e37a68abf,
  username: 'testUser',
  password: 'Xa8S8qxXsQqAvenX5Kk4BloZfX1XePosVCNXoyLBQz4=',
  mail: 'test@user.com',
  salt: 'hDsCu0CShRbE/XFAvw6y/8SLu4vufP7a7ewiCBLXIQ0=',
  __v: 3 }

這是我在 TS 中所做的:

let userQuery = await UserModel.find({

  "devices.refreshToken": refreshToken,
  "devices.active": true

});

let userInfo:any = userQuery[0];

if(!userInfo){

  reject("Invalid token");
  return;

}

let device = userInfo.devices.filter(_device => _device.refreshToken == refreshToken)[0];

userInfo.updateOne( { _id: userInfo._id , "devices._id": device._id},{ $set: {"devices.$.active":false} });

每個設備都是這樣生成的:

let userDevice = new DeviceModel({

  ...device,
  refreshToken,
  active:true,

});

userInfo.devices.push(userDevice);

問題是設備數組中的數據永遠不會更新,即使查詢正常工作

我建議您首先使用代碼中的 mongoDB 來檢查查詢,例如使用 Robo 3T:

對於您的情況,請嘗試以下操作:

db.getCollection('YOUR COLLECTION NAME HERE').updateOne({ '_id': 5f4c05c64708cf0e37a68abf ,'devices._id': 5f4c05cb4708cf0e37a68ac0 }, { $set: { 'devices.$.active': false }});

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM