моя схема выглядит так:
{
"blogTitle":"Book"
"blogContent":"demo"
"blogrelatedLink":{
"relatedBloogId:"123",
"relatedBlogTitle":"abc"`
}
}
и мой код:
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 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 }
);
sendResponse(200, "Successfull", blog, req, res);
} catch (err) {
sendError(400, "Blog can't be updated by given id", err, req, res);
}
}
};
какой будет код для обновления поддокумента



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Ключ обновления должен быть в этом формате <main key name>.<sub key name>: <value to be update>, просто поместите его перед запросом на обновление,
if (req.body.blogrelatedLink) {
for (let key in req.body.blogrelatedLink) {
update['blogrelatedLink.' + key] = req.body.blogrelatedLink[key];
}
}
другие поля обновляются? это идентификатор монго blogId? затем преобразуйте его в тип объекта mongoose.Types.ObjectId(blogId)
blogId - это то, что я предоставляю, или вы можете увидеть его собственный идентификатор, даже если вы можете изменить его в монго, когда я открываю его отображение следующим образом (downKey) ↓ blogRelatedLinks: Array (downKey) ↓ 0: Object _id: objectid (1233454), relatedBlogId: 12323454, relatedBlogTitle: "демо"
я не уверен, что в вашем коде чего-то не хватает, я только что добавил рабочую ссылку playgroud в свой ответ, вы можете просто консоль и отладить свой код.
хорошо, я проверю, но спасибо @turivishal
я пытался, но все еще не обновляется в моей mongoDB, но спасибо @turivishal