我目前正在开发一个项目,我不得不将项目插入数据库中的数组/对象。我想要做的是将'upvoted'帖子的ID添加到'User'Collection中的数组/列表中,但是,我似乎无法让它工作。
我的架构的代码如下:
// this is a child scheme/sub-document
var uvpSchema = new Schema();
uvpSchema.add({
post: String
});
var dvpSchema = new Schema();
dvpSchema.add({
post: String
});
//main schema
var userSchema = new Schema({
firstname: { type: String, required: true },
lastname: { type: String, required: true },
username: { type: String, required: true, unique: true },
password: { type: String, required: true },
upVotedPosts: [uvpSchema],
downVotedPosts: [dvpSchema],
created_at: Date,
});
这是我的'routes.js'中的代码,用于将帖子的id插入数组中:
var newPush = {
post: postID // postID is a variable that I have already defined
};
User.findOneAndUpdate({username: req.session.user}, {$push: {upVotedPosts: newPush}}, {upsert: true, save: true}, (err, user) => {
if (err) console.log(err);
user.upVotedPosts.push(newPush);
User.save;
res.redirect(req.get('referer'));
console.log(user.upVotedPosts);
});
我在终端收到的错误是:
{ _id: 595f68b5fadd49105813f8a4 },{ _id: 595f693d3c2c21189004b0a7 },{ _id: 595f70a2df80e0252894551b }
events.js:163
throw er; // Unhandled 'error' event
^
提前致谢; - )
答案 0 :(得分:0)
Route.js
User.findOneAndUpdate({username: req.session.user}, {$push: {upVotedPosts: newPush}}, {upsert: true, save: true}, (err, user) => {
if (err) console.log(err);
user.upVotedPosts.push(newPush);
User.save;
res.redirect(req.get('referer'));
console.log(user.upVotedPosts);
});
你不需要显式推送,因为你推动了使用findOneandUpdate - $ push
参考here
其次,它的
user.save()
而不是
User.save
答案 1 :(得分:0)
首先,我要感谢大家的'帮助; - )
我终于设法让部分工作了!我的问题是我的函数异步运行,导致一些问题。我通过向每个mongoose函数添加回调函数来解决这个问题。
但是,仍然返回相同的错误,导致服务器崩溃。其他一切都有效;新项目已添加到数组中。
无论如何都要忽略错误,以免服务器崩溃?