Node.js Mongoose Schema.update不';t更新布尔值

Node.js Mongoose Schema.update不';t更新布尔值,node.js,mongodb,express,Node.js,Mongodb,Express,我尝试过更新其他字段,效果很好 我在API中使用的命令: User.update({ email: targetUser.email }, { $set: { isAdmin: true }, $push: { 'log.updated': new Date() } }, function (err, user) { if (err) { responseObject.err = err; responseObject.data = null; responseO

我尝试过更新其他字段,效果很好

我在API中使用的命令:

  User.update({ email: targetUser.email }, { $set: { isAdmin: true }, $push: { 'log.updated': new Date() } }, function (err, user) {
  if (err) {
    responseObject.err = err;
    responseObject.data = null;
    responseObject.code = 422;

    return res.json(responseObject);
  }


  return res.json(responseObject);
});
要澄清的是,当我尝试运行此程序时,API返回一个代码200,这意味着一切正常,但当我检查数据库时,isAdmin值没有更改

任何建议都会很有帮助,这里没有想法了

请求的用户架构:

var UserSchema = new Schema({
  name: { type: String, default: "", index: 'text' },
  email: { type: String, lowercase: true },
  role: { type: String, default: "" },
  meta: {
    skills: { type: Array, default: [], index: 'text' },
    about: { type: String, default: "", index: 'text' },
    education: { type: Array, default: [], index: 'text' },
    location: {
      address: {
        a: { type: String, default: "" },
        p: { type: String, default: "" },
        c: { type: String, default: "" }
      },
      geo: {
        lat: { type: Number, default: 0 },
        lng: { type: Number, default: 0 }
      }
    }
  },

  compMeta:
  {
    departments: { type: Array, default: [], index: 'text' },
    employees:
    [
      {
        emId: Number,
        empName: String,
        empDep: String  // Dunno if i should use Dep name or Dep ID gonna look in to that later
      }
    ],
  }
  ,
  settings: {
    search: {
      distance: {
        n: { type: Number, default: 100 },
        t: { type: String, default: "km" }
      }
    }
  },
  created: {
    type: Date,
    default: Date.now
  },
  //Rating is an array of objects that consist of rateing 0-100 , job database id , comments from the Company
  rating:
  [
    {
      rate: Number,
      jobId: Number,
      jobComments: String
    }
  ],
  /*rating:
  {
    userTotalRating: {type: Number, default: 0},
    ratingCounter : {type: Number, default: 0}
  }*/


  sensitive: {
    cpr_cvr: String,
  },
  stripe: { type: String },
  facebook: {},
  linkedin: {},
  log: {
    updated: { type: Array, default: [] }
  },
  hashedPassword: String,
  provider: { type: String, default: 'local' },
  salt: String
});
更新:


Mongodb版本:3.0.7

尝试使用$set更新两个字段

User.update({ email: targetUser.email }, { $set: { isAdmin: true, 'log.updated': new Date() } }, function (err, user) {
 if (err) {
responseObject.err = err;
responseObject.data = null;
responseObject.code = 422;

return res.json(responseObject);
 }
 return res.json(responseObject);
});

希望它能起作用。

原来我只是忘了将isAdmin字段添加到我的用户模式中!另外,我对更新的调用错误,我将其更改为:

User.update({ email: targetUser.email }, { $set: { isAdmin: true }}, { $push: { 'log.updated': new Date() } }, function (err, user) {
  if (err) {
    responseObject.err = err;
    responseObject.data = null;
    responseObject.code = 422;

    return res.json(responseObject);
  }


  return res.json(responseObject);
});

感谢所有努力帮助我的人!:)

我遇到了类似的问题。解决方案是添加回调

这不起作用:

Ride.updateOne({driver:req.body.id},{$set:{isBusy:true}});
这项工作:

Ride.updateOne({driver:req.body.id},{$set:{isBusy:true}},(e,s)=>{});

有什么问题吗?不清楚,我添加了一个小说明,希望能有所帮助:)我也能看到模式模型吗?@Michelem,我已经用模式更新了问题!我看不到isAdminfieldHey Mariya,不幸的是我得到了同样的结果。我也尝试了,没有改变。最后一次尝试。。更新了代码。还有一件事,如果它成功,那么您将作为responseName获得true,返回一个200代码,然后数据库中没有任何更改。此处完全相同(:此处相同,我还忘了在Schema上添加字段。立即修复!