Я работаю в системе баз данных, используя MongoDB. Я пытаюсь сохранить текущую дату и время, а затем обновить его, если один и тот же штрих-код на идентификационных картах сканируется дважды, трижды и т. Д. Однако набор $ не будет обновлять элемент. Я уже просмотрел документацию MongoDB и другие сообщения о переполнении стека, но, похоже, ничего не работает. Другие сообщения о переполнении стека предложили добавить
{ new: true }
и
( overwrite: true }
Я пробовал это как по отдельности, так и в тандеме, ни один не работал.
Мой код:
Student.findOne({StudNum: studNum}, function(err, studNumItem) {
if (err) {
res.send("MongoDB Error: " + err);
return false;
}
if (!studNumItem) {
var myData = new Student({ StudNum: studNum, Attendance : 1, LastDateTimeAttended : {
Year: year, Month: month, Day: day, Hours: hours, Min: min, Sec: sec
}});
myData.save()
.then(item => {
res.send("saved to database: " + studNum + ", with attendance " + Attendance + "");
})
.catch(err => {
res.send("unable to save to database: " + studNum + ", for attendance " + Attendance + "");
});
}
else{
var conditions = {StudNum: studNum};
var update = {$inc : { Attendance: 1 }, $set : {
"Year": year, "Month": month, "Day": day, "Hours": hours, "Min": min, "Sec": sec
}};
Student.findOneAndUpdate(conditions, update, { new: true }, function (err)
{
if (err) // If error
{
res.send(err);
}
else {
res.send("Checked in!")
}
});
}
});
И моя схема:
var studentSchema = mongoose.Schema({
StudNum: String,
Attendance: Number,
LastDateTimeAttended: {
Year: Number,
Month: Number,
Day: Number,
Hours: Number,
Min: Number,
Sec: Number
}
});
Заранее спасибо!
Редактировать: просто чтобы уточнить, сохранение элемента работает нормально, но обновление элемента - нет, также не выдается никаких ошибок при обновлении.