我正在尝试使用 MongoDB 的 Java 驱动程序在同一操作中对记录进行两次更新($set 和 $push)。我正在使用类似于以下的代码:
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);
当我通过 BasicDBList 将 $set 和 $push 组合到同一个更新中时,我得到一个 IllegalArgumentException:“存储在 db 中的字段不能以 '$' 开头(坏键:'$push')”。
如果我进行两次单独更新,pushUpdate 和 setUpdate 都会产生有效结果。
谢谢!
最佳答案
我不知道 Java 驱动程序,但是你必须在那里创建一个列表吗?如果您尝试此代码会发生什么?
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);
这应该产生相当于
db.collection.update({_id: pageId}, {$push: {values: dboVital}, $set: {endTime: time}});
而你的代码产生(我怀疑)这个:
db.collection.update({_id: pageId}, [{$push: {values: dboVital}}, {$set: {endTime: time}}]);
关于java - $push 和 $set 在同一个 MongoDB 更新中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9071192/