MongoDB объект не обновляется - PullRequest
0 голосов
/ 02 сентября 2018

Я работаю в системе баз данных, используя 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
}
});

Заранее спасибо!

Редактировать: просто чтобы уточнить, сохранение элемента работает нормально, но обновление элемента - нет, также не выдается никаких ошибок при обновлении.

Ответы [ 2 ]

0 голосов
/ 02 сентября 2018

Я предлагаю вам сохранить дату в виде строки. LastDateTimeAttended в вашей модели должен ожидать строку, а новый конструктор Student должен создать переменную LastDateTimeAttended, вызвав

let date = new Date();
LastDateTimeAttended = date.toString();

ваша новая схема должна выглядеть как

var studentSchema = mongoose.Schema({
StudNum: {type: String, required: true},
Attendance: {type: Number, required: true},
LastDateTimeAttended: {type: String, required: true}
});

тогда вы сможете обновить документ mongodb Student.findOneandUpdate (условия, обновление, обратный вызов). см. Работу с мангустом Model.findOneandUpdate

0 голосов
/ 02 сентября 2018

В вашем случае, я не уверен, что это ваша проблема с поиском и обновлением. Я полагаю, поскольку то, что вы пытаетесь обновить, является вложенным объектом, вам нужно добавить его к свойству верхнего уровня, чтобы мангуста сохранила его. Поскольку эти свойства не существуют на верхнем уровне, Мангуста просто выбрасывает их.

var update = {$inc : { Attendance: 1 }, $set : {
    "LastDateTimeAttended.Year": year, "LastDateTimeAttended.Month": month, "LastDateTimeAttended.Day": day, "LastDateTimeAttended.Hours": hours, "LastDateTimeAttended.Min": min, "LastDateTimeAttended.Sec": sec
  }};
...