sql >> Databasteknik >  >> NoSQL >> MongoDB

Upsert Array Elements matchande kriterier i ett MongoDB-dokument?

Det du behöver är inte möjligt med en enda uppdatering utan någon logik på appsidan. Observera att upsert som en funktion inte är relevant för detta specifika problem om du inte automatiskt vill skapa nya widgetdokument om det inte finns några med det angivna namnet.

Problemet du stöter på är att det inte finns någon funktion som låter dig göra två olika uppdateringar beroende på att det finns ett array-element. Dina enda två alternativ är:

  1. Hitta objektet, bestäm förekomsten av relevanta egenskaper, kompilera en lämplig uppdatering med dina nya eller ändrade egenskaper och kör den. Detta kommer med den viktiga nackdelen att detta inte är en samtidighetssäker metod. Med andra ord, om två webbtjänster försöker detta samtidigt kan man skriva över varandras ändringar.
  2. Gör widgetegenskaper till dokument på toppnivå i stället för inbäddade. Låter dig använda upserts för att göra vad du vill. Uppenbar nackdel är att det inte är ett särskilt trevligt alternativ när det gäller schemadesign. Du skulle inte automatiskt få alla egenskaper om du till exempel hämtar en widget.


  1. Yii2 + Redis som databas

  2. Anpassade felmeddelanden med Mongoose

  3. MongoDB $runda

  4. MongoDB:Hitta underdokument i Array Matching Parameters