$ push et $set dans la même mise à jour MongoDB
J'essaie d'utiliser le pilote Java de MongoDB pour effectuer deux mises à jour ($set et $push) sur un enregistrement dans la même opération. J'utilise un code similaire à ce qui suit:
BasicDBObject pushUpdate = new BasicDBObject().append("$push", new BasicDBObject().append("values", dboVital));
BasicDBObject setUpdate = new BasicDBObject().append("$set", new BasicDBObject().append("endTime", time));
BasicDBList combinedUpdate = new BasicDBList();
combinedUpdate.add( pushUpdate);
combinedUpdate.add( setUpdate);
collection.update( new BasicDBObject().append("_id", pageId), combinedUpdate, true, false);
Lorsque je combine $set et $push dans la même mise à jour via un BasicDBList, j'obtiens une IllegalArgumentException: "les champs stockés dans la base de données ne peuvent pas commencer par '$' (Bad Key: '$push')".
Si je fais deux mises à jour distinctes, pushUpdate et setUpdate produisent des résultats valides.
Merci!
24
demandé sur
Parvin Gasimzade
2012-01-31 01:41:48
1 réponses
Je ne connais pas le pilote Java, mais devez-vous créer une liste là-bas? Qu'advient-il si vous essayez ce code?
BasicDBObject update = new BasicDBObject().append("$push", new BasicDBObject().append("values", dboVital));
update = update.append("$set", new BasicDBObject().append("endTime", time));
collection.update( new BasicDBObject().append("_id", pageId), update, true, false);
Cela devrait produire l'équivalent de
db.collection.update({_id: pageId}, {$push: {values: dboVital}, $set: {endTime: time}});
Alors que votre code produit (je soupçonne) ceci:
db.collection.update({_id: pageId}, [{$push: {values: dboVital}}, {$set: {endTime: time}}]);
44
répondu
Sergio Tulentsev
2012-01-30 21:54:27