Compte tenu de ce document enregistré dans MongoDB
{
_id : ...,
some_key: {
param1 : "val1",
param2 : "val2",
param3 : "val3"
}
}
Un objet contenant de nouvelles informations sur param2
et en param3
provenance du monde extérieur doit être enregistré
var new_info = {
param2 : "val2_new",
param3 : "val3_new"
};
Je veux fusionner / superposer les nouveaux champs sur l'état existant de l'objet afin que param1 ne soit pas supprimé
Ce faisant
db.collection.update( { _id:...} , { $set: { some_key : new_info } }
Mènera à MongoDB fait exactement comme il a été demandé, et définit some_key sur cette valeur. remplacer l'ancien.
{
_id : ...,
some_key: {
param2 : "val2_new",
param3 : "val3_new"
}
}
Comment faire pour que MongoDB ne mette à jour que les nouveaux champs (sans les déclarer explicitement un par un)? pour obtenir ceci:
{
_id : ...,
some_key: {
param1 : "val1",
param2 : "val2_new",
param3 : "val3_new"
}
}
J'utilise le client Java, mais tout exemple sera apprécié