我有一个函数,它将新日期添加到“举行的类(class)”日期数组中。
最初,我有一个从在线示例复制的函数,该函数不是异步的。它使用了一个简单的 Mongoose 'document.save' 调用,并且在几天内运行良好。然后它停止更新数组。
所以我做了一些调试,并认为我可能需要一个异步函数,但这也不起作用。我知道我做错了什么,但我不知道它是什么。
这是我的代码,其中包含 console.logs 以显示该函数正在执行的操作:
this.updateDate = async function () {
try {
let today = this.getFullDate(); // returns a string that I use as a date in the database
await Admin.findOne({'local.className':'2018'}).then(function(course){
console.log('today: '+today);
console.log('course: '+course);
let classesHeld = course.local.classesHeld;
console.log('classesHeld: '+classesHeld);
console.log('index: '+classesHeld.indexOf(today));
if(classesHeld.indexOf(today)=== -1){
classesHeld.push(today);
console.log('added today: '+classesHeld);
Admin.update({'local.className':'2018'},{'local.classesHeld':classesHeld});
console.log('saved it');
}
else{
console.log('Today\'s date already in database.');
}
});
} catch (error) {
console.log('Error in update date: ' + error);
}
}
这是我在控制台中看到的内容:
today: 7/26/2018
course: { _id: 5b57904b0bed9d3004979604,
__v: 0,
local:
{ className: '2018',
classesHeld:
[ '7/16/2018',
'7/17/2018',
'7/18/2018',
'7/19/2018',
'7/23/2018',
'7/24/2018',
'7/25/2018' ] } }
classesHeld:
7/16/2018,7/17/2018,7/18/2018,7/19/2018,7/23/2018,7/24/2018,7/25/2018
index: -1
added today:
7/16/2018,7/17/2018,7/18/2018,7/19/2018,7/23/2018,
7/24/2018,7/25/2018,7/26/2018 // this is correct
saved it // nope
感谢任何帮助。
最佳答案
尝试:
await Admin.update({'local.className':'2018'},{$set{'local.classesHeld':classesHeld}});
而不是:
Admin.update({'local.className':'2018'},{'local.classesHeld':classesHeld});
关于javascript - 为什么这个 Mongoose 更新没有保存到数据库中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51544609/