使用Java驱动程序更新MongoDB中的数组
我正在使用MongoDB和官方Java驱动程序(版本2.6.3)。我有一个包含购物清单的MongoDB集合。购物清单具有以下格式
{ "_id" : { "$oid" : "4e2af1f43f8de96494d5271d"} ,
"name" : "default" ,
"items" : [ { "description" : "Cheese" , "quantity" : 1 , "unit" : "kg"} ,
{ "description" : "Water" , "quantity" : 3 , "unit" : "bottle"} ] }
现在我想用.但无论我尝试什么,它都不会起作用,尽管它告诉我update()
DBCollection
{ "updatedExisting" : true , "n" : 1 , "connectionId" : 63 , "err" : null , "ok" : 1.0}
我的代码执行以下操作:
BasicDBObject updateQuery = new BasicDBObject();
updateQuery.put( "name", "default" );
BasicDBObject updateCommand = new BasicDBObject();
updateCommand.put( "$push", new BasicDBObject( "items", newShoppingItem ) );
WriteResult result = shoppingLists.update( updateQuery, updateCommand, true, true );
newShoppingItem
是包含新项的数据的 。我也尝试使用 和 创建参数,但这没有任何区别。BasicDBObject
update()
BasicDBObjectBuilder
JSON.parse()
我也看了一下其他帖子,尝试谷歌,但无济于事。我做错了什么?
感谢您的任何帮助!
奥利弗