JSON对象字段删除中的MongoDB JSON数组

时间:2012-10-24 19:38:19

标签: java android mongodb

我有一个json对象如下:

{ "_id" : ObjectId("508806803bb97dc546e6f307"), "user_name" : "user1", "user_id" : 45645645, "likes" : [ { "event_id" : NumberLong("4578541212") },{ "event_id" : NumberLong("4578541213") } ], "dislikes" : [ ] }

我正在尝试通过java驱动程序删除likes数组中的特定事件 尝试在shell中首先执行此操作:

> db.users.update( {'likes.event_id' : 4578541212}, { '$unset':{'likes.event_id'
:1}})
没有运气......我怎么能做到这一点?

1 个答案:

答案 0 :(得分:1)

如果您只想从数组元素中删除event_id字段:

db.users.update( {'likes.event_id' : 4578541212}, {'$unset':{'likes.$.event_id' :1}})

使用$pull运算符删除元素:

db.users.update({'likes.event_id': 4578541212}, {'$pull':{likes: {event_id: 4578541212}}})