Wymagane kilka poprawek w zapytaniu, w przeciwnym razie jest prawie na miejscu. Aktualizacja nie działa, ponieważ $elemMatch
dla attributeSet
(tablica dokumentów) ma nastąpić na id
właściwość tych dokumentów do filtrowania, a nie attributeSet.id , nie domyśli się, co to jest. Zagnieżdżony element elemMatch nie jest wymagany, po prostu użyj notacji z kropkami .
Aby debugować, możesz wypróbować to za pomocą zapytania wyszukiwania.
Zapytanie (powłoka):
db.collection.findOneAndUpdate(
{
_id: settingsToBeUpdated._id,
attributeSet: {
$elemMatch: {
id: attributeSetId,
"attributes.id": id
}
}
},
{
$set: {
"attributeSet.$[as].attributes.$[a].attributeName":
attributeDto.attributeName,
"attributeSet.$[as].attributes.$[a].defaultValue":
attributeDto.defaultValue,
"attributeSet.$[as].attributes.$[a].isRequired": attributeDto.isRequired
}
},
{
arrayFilters: [{ "as.id": attributeSetId }, { "a.id": id }],
returnNewDocument: true
}
);