Я хочу обновить "displayTitle" до "12345", где objectId равен "5d8c8f4a4449a851f6kkk6o2" в "title" of topten = "до 50000" findOneAndUpdate для вложенных объектов-элементов массива с двумя условиями, сначала для выбора конкретного документа ивторой, чтобы найти конкретный объект во вложенном массиве. Имя коллекции: topten.
> db.topten.find().pretty();
{
"_id" : ObjectId("5d8c8f254449a851f6aaa6r3"),
"title" : "under 50000",
"products" : [
{
"_id" : ObjectId("5d8c8f4a4449a851f6kkk6o2"),
"productId" : "5cfe541ae759d9699b5213542",
"displayTitle" : "dhtyks",
"score" : 100,
"priority" : 50,
"description" : "Upcoming"
},
{
"_id" : ObjectId("5d8c8f8f4449a86544646"),
"productId" : "5cfe512bca044365efsdfgg45",
"displayTitle" : "Spice",
"score" : 10,
"priority" : 800,
"description" : "Advanced"
}
],
"created" : ISODate("2019-09-26T10:12:53.804Z"),
"updated" : ISODate("2019-10-03T05:24:19.296Z"),
"slug" : "under-10000",
"__v" : 0
{
"_id" : ObjectId("5d8c8f254449a851f6ddd9a1"),
"title" : "under 10000",
"products" : [
{
"_id" : ObjectId("5d8c8f4a4449a851f6ddd9a2"),
"productId" : "5cfe541ae759d9699b56759b",
"displayTitle" : "ABCDEF6",
"score" : 10,
"priority" : 200,
"description" : "New Gen"
},
{
"_id" : ObjectId("5d8c8f8f4449a851f6ddd9a4"),
"productId" : "5cfe512bca044365ef1dcd0f",
"displayTitle" : "Micromax",
"score" : 1,
"priority" : 200,
"description" : "Upcoming"
}
],
"created" : ISODate("2019-09-26T10:12:53.804Z"),
"updated" : ISODate("2019-10-03T05:24:19.296Z"),
"slug" : "under-10000",
"__v" : 0
Код, который я использую для этого:
topten.findOneAndUpdate({"title" : "under 50000", "products": { $elemMatch: { "_id": "5d8c8f4a4449a851f6kkk6o2" } }},
{"products.0.displayTitle":"12345"},
function (err, doc) {
if (err) {
console.log(err);
reject(new Error(err));
return;
} else {
console.log('AAAAAAAAAAAAAAAAAAAAAAAA', doc)
res.status(200)
.json({
success: true,
msg: 'Attached product updated succesfully`);'
})
}
}
)
Запрос запущен, но значение в моем БД не обновляется. Пожалуйста, помогите, я застрял здесь.