#javascript #node.js #mongodb #mongoose #mongodb-query
#javascript #node.js #mongodb #mongoose #mongodb-запрос
Вопрос:
Я хочу обновить какой-либо один ключ, но я не знаю, как указать ИЛИ условие — это любой способ, которым я могу добавить ИЛИ условие для обновления любого одного ключа или обоих ключей одновременно.
const updateBlogs = async (req, res) => {
const { blogId } = req.params;
const re = /<("[^"]?"|'[^']?'|[^'">])*>/;
if (re.test(req.params.blogTitle)) {
sendError(400, "Unsuccessful", "Blog Title cannot be HTML", req, res);
} else {
try {
let blog = await Blog.updateOne(
{ blogId },
{
$set: {
blogTitle: req.body.blogTitle,
blogContent: req.body.blogContent,
},
},
{ runValidators: true }
);
sendResponse(200, "Successfull", blog, req, res);
} catch (err) {
sendError(400, "Blog can't be updated by given id", err, req, res);
}
}
};
Комментарии:
1. Когда вы говорите ключи, вы имеете в
blogTitle
виду иblogContent
?2. да @MontgomeryWatts
Ответ №1:
Вы можете создать документ обновления заранее в зависимости от того, какие поля доступны в req.body
.
Вот один из примеров:
let update = {};
if (req.body.blogTitle) update.blogTitle = req.body.blogTitle;
if (req.body.blogContent) update.blogContent = req.body.blogContent;
let blog = await Blog.updateOne(
{ blogId },
{
$set: update,
},
{ runValidators: true }
);
Как вы можете видеть, поля устанавливаются, только если они присутствуют в запросе, и передаются в обновление. Имейте в виду, что это решение предполагает, что хотя бы одно из полей будет присутствовать — если будет передан пустой документ обновления $set
, вы получите сообщение об ошибке.