$ 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