Node.js Mongoose Schema.update不';t更新布尔值
我尝试过更新其他字段,效果很好 我在API中使用的命令: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
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上添加字段。立即修复!