我在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 }
})
文档数组未更新。我找不到错误。
答案 0 :(得分:5)
看起来您需要的是$addToSet。示例:
Job.findOneAndUpdate({ _id: req.params.id }, { $addToSet: { appliedUser: req.user.id } }, function(err, job) {
console.log(job);
})