37

我正在尝试使用 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 都会产生有效的结果。

谢谢!

4

2 回答 2

58

我不知道 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}}]);
于 2012-01-30T21:45:52.257 回答
-1

我的 mongodb 版本是 3.4.20 并且在使用时

db.collection.update({_id: pageId}, [{$push: {values: dboVital}}, {$set: {endTime: time}}]);

我收到错误

[thread1] Error: field names cannot start with $ [$push] :

为了解决这个错误,我们可以使用:

db.collection.update({_id: pageId}, {$push: {values: dboVital}, $set: {endTime: time}});
于 2019-07-02T07:03:06.037 回答