Mongoose .findOne 错误返回找到的模型?

Buc*_*ets 1 javascript mongoose mongodb node.js

所以我试图通过在 mongoose 中使用 findOne 函数来访问这个帐户,并且我试图控制台.记录错误,但错误只是找到了正确的模型..一旦我找到了我想要访问的正确模型模式中的嵌套对象之一,因此我可以编辑该值。

我不确定为什么会发生这种情况,下面我将代码以及登录到控制台的错误放在下面,如果需要,我可以提供更多信息。

    let accountSchema = mongoose.Schema({
       username:{
           type: String,
           required: true,
           index: true,
           unique: true,
       },
       password:{
           type: String,
           required: true,
       },
       money:{
           type: Number,

       },
       inventory: { type: [{
           weed: { type: Number },
           coke: { type: Number },
       }]},
  });


mp.events.addCommand('coke', (player) => {
    console.log(player.name);
    Account.findOne({username: 'a'}, function(acc, err) {
        if(err) return console.log(err);
        console.log(acc.username);
       acc.inventory[1] = acc.inventory[1] + 1;
       acc.save(function(err){
          if(err) return player.outputChatBox('Not logged in');
          player.outputChatBox('Added 1 coke');
       });
    });
});

(Console) {"_id":"5b6acbbbc285477e39514cb9","username":"a","password":"$2a$10$XABqooqFRINYVdJ79.i2E.5xdpitRrfZxUBmIPAZjjaXKvvLDc2y2","money":5000,"inventory":[{"_id":"5b6acbbbc285477e39514cbb","weed":0},{"_id":"5b6acbbbc285477e39514cba","coke":0}],"__v":0}
Run Code Online (Sandbox Code Playgroud)

Tsv*_*nev 6

.findOne方法的回调函数具有以下签名:

function (err, obj) {

}
Run Code Online (Sandbox Code Playgroud)

您以错误的顺序使用参数 - 错误对象是第一个参数,找到的对象是第二个。