我试图使用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:"数据库中存储的字段不能以"$"开头(坏键:"$push").

如果我进行两次单独的更新,pushUpdate和setUpdate都会生成有效的结果.

谢谢

推荐答案

我不知道Java驱动程序,但是你需要在那里创建一个列表吗?如果你try 这个代码会发生什么?

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}}]);

Mongodb相关问答推荐

MongoDB更新对象数组

如何在MongoDB中查找和过滤嵌套数组

Mongo 聚合查找 $gte 6 个月前的日期,以DD-MM-YYYY格式存储为字符串

从 node.js 的 mongodb 集合中删除文档

如何在 Mongo 聚合管道中获取限制之前的计数

Mongodb插入没有_id字段的文档

MongoDB - 清除嵌套数组中的元素

升级mongodb

MongoDB:单个数据库处理程序的 >5 个打开连接

MongoDB:在集合上设置 TTL 索引时出错: sessions

有没有办法将python对象直接存储在mongoDB中而不序列化它们

MongoDB中超过2GB的数据库

Cannot connect to MongoDB errno:61

Python Django-REST-framework 和 Angularjs 的文件夹 struct

如何从 Mongoose 模型对象中获取集合名称

如何仅通过一次调用将一组对象保存到mongoose数据库?

MongoDB 中的多个 $inc 更新

在 mongoose 中使用 UUID 进行 ObjectID 引用

如何通过mongoose更新 mongodb 中的对象?

全局初始化失败:BadValue Invalid or no user locale set.请确保正确设置 LANG 和/或 LC_* 环境变量