MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

Aktualisieren Sie verschachtelte Array-Objekte basierend auf einer Eigenschaft in MongoDB

Sie müssen $ positional verwenden Operator zum Aktualisieren eines Array-Elements und mit multi: true Option können Sie mehrere Dokumente mit derselben Übereinstimmung aktualisieren

db.collection.update(
  { 'items': { '$elemMatch': { 'itemName': 'Name 1' }}},
  { '$set': { 'items.$.itemName': 'New Name' }},
  { 'multi': true }
)

und mit der mongodb 3.6 arrayFilters

db.collection.update(
  { 'items': { '$elemMatch': { 'itemName': 'Name 1' }}},
  { '$set': { 'items.$[item].itemName': 'New Name' }},
  { 'arrayFilter': [{ 'item.itemName': 'Name 1' }], 'multi': true }
)