Ако искате да използвате оператор $
в частта за актуализиране, трябва изрично да напишете that array
в частта за заявка. И така,
mongoTemplate.updateFirst(
query(where("name").is("Award1")),
Update.update("brand.$.descr", "Desc2"),
Awards.class);
трябва да бъде
mongoTemplate.updateFirst(
query(where("name").is("Award1"))
.and("brand.name").is("Brand1"), // "brand" in "brand.name" is necessary, others according to your requirement
Update.update("brand.$.descr", "Desc2"),
Awards.class);
Ако знаете позицията на елемента в масива, `$' не е необходимо, можете да опитате така:
mongoTemplate.updateFirst(
query(where("name").is("Award1")),
Update.update("brand.0.descr", "Desc2"), // 0 is the index of element in array
Awards.class);
Същият начин за обработка на name
поле.