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

Spring Data Mongo:Upsert mit verschiedenen aktualisierten Feldern

Ich glaube, wonach Sie suchen, ist $setOnInsert für subdocument1 . Also sollte so etwas für Sie funktionieren.

Query query = Query.query(Criteria.where("_id").is("some_id"));
Update update = Update.update("_id", "some_id")
                .set("field1", "value1")
                .set("field2", "value2")
                .set("subdocument2", subdocumentObject2)
                .setOnInsert("subdocument1", subdocumentObject1);

Mehr hier https://docs.mongodb.com/manual/reference/ operator/update/setOnInsert/