MongoD:如何更新集合中文档的特定字段?

时间:2019-10-25 10:29:49

标签: node.js mongoose

我在MongoDB中有一个职位的集合,在这个集合中,文档中有一个名为AppliedUser的字段。我想在新用户申请此职位时更新此字段。因此,基本上,该字段存储了所有正在申请此职位的用户的ID。

我正在使用findOneAndUpdate()函数,但无法执行。

Job.findOneAndUpdate({ _id: req.params.id }, { $set: { appliedUser: 
req.user.id } }, function(err, job) {
    console.log(job);
})

这是我的架构:

const jobSchema = new Schema({
date: { type: Date, default: Date() },
expirydate: { type: Date, required: true },
name: { type: String, required: true },
companydetails: { type: String, required: true },
address: { type: String, required: true },
role: { type: String, required: true },
city: { type: String, required: true },
minsalary: { type: Number, required: true },
maxsalary: { type: Number, required: true },
skills: { type: Array, required: true },
minex: { type: Number, required: true },
appliedUser: [{ type: Schema.Types.ObjectId, ref: 'users', unique: 
true }],
user: { type: String, required: true }

})

文档数组未更新。我找不到错误。

1 个答案:

答案 0 :(得分:5)

看起来您需要的是$addToSet。示例:

Job.findOneAndUpdate({ _id: req.params.id }, { $addToSet: { appliedUser:  req.user.id } }, function(err, job) {
  console.log(job);
})