могу ли я применить ИЛИ условие здесь в mongoose (mongodb)

#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 , вы получите сообщение об ошибке.