我的数据来自用户,并存储为一个对象,在服务器端进行一些按摩后,该对象需要进入Mongo。我正在使用Mongoose,并使用$push {item}
语法将一个项目插入数据库。
我的猫鼬模型的语法为photos: []
,只是一个简单的数组。在该阵列内部,我需要上传照片。但是,如果用户在不同的时间上传,则我的数组最终可能是一个数组数组,而我只需要一个带有多个对象的简单数组。
这是我的路线:
const testMedia = async (req, res) => {
//loop through the res.locals.ids and save each as their own photo in the event
let events = [];
let photosArray =
let owner = {id: req.user._id};
const promises = await res.locals.ids.map((photoLink) => {
events.push({link: photoLink.link,
dateUploaded: new Date(Date.now()).toLocaleString(),
eventID: req.body.eventId,
owner: owner
})
});
await Event.findByIdAndUpdate(
req.body.eventId,
{ $push: {
photos: events
}},
{ save: true, upsert: true, new: true },
(err) => {
if (err){
console.log("Error in testMedia || " + err);
res.sendStatus(300);
}
}
);
await Promise.all(promises);
res.render("eventDisplay", { events: event });
res.end();
};
我遇到的问题是,如果我将项目推入events
中,那么当我只需要对象本身时,我将推入一个对象数组,因此我要么必须为每个对象进行一个数据库调用插入,这似乎浪费资源,或者我需要找到一种方法来插入所有对象而不将它们包装在数组中。
由于某种原因,我无法弄清楚。有任何想法吗?
答案 0 :(得分:1)
根据Mongo文档,您可以使用$each
.findByIdAndUpdate(req.body.eventId, {
$push: {
photos: { $each: events }
}
})
这会将多个项目推入您的数组。