首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用MongoDB-Java驱动程序从数组中删除条目

使用MongoDB-Java驱动程序从数组中删除条目
EN

Stack Overflow用户
提问于 2012-04-11 06:56:35
回答 2查看 9.9K关注 0票数 10

我有像这样的JSON:

代码语言:javascript
复制
{ 
    "_id" : "1",
    "_class" : "com.model.Test",
    "itemList" : [
        {
            "itemID" : "1",
            "itemName" : "Foo",
            "resources" : [ 
                { 
                    "resourceID" : "1",
                    "resourceName" : "Foo Test1"
                 }, {
                    "resourceID" : "2",
                    "resourceName" : "Foo Test2"
                 }
             ]
        }
    ]
}

我需要能够删除itemList的一条记录。我做了以下工作:

代码语言:javascript
复制
public void removeItemByID(String docID, String itemID) throws Exception {
    MongoOperations mongoOperations = mongoConfiguration.getMongoTemplate();
    Query query = new   Query(where("_id").is(docID).and("itemList.itemID").is(itemID));
    mongoOperations.remove(query, Item.class);

}

这种方法行不通。但是,当我使用带有$pull方法的BasicDBObject时,它工作得很好!这些方法之间有什么不同!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-04-11 13:36:48

如果你想删除一个数组,我通常使用以下方法:

代码语言:javascript
复制
BasicDBObject match = new BasicDBObject("_id", "1"); // to match your document
BasicDBObject update = new BasicDBObject("itemList", new BasicDBObject("itemID", "1"));
coll.update(match, new BasicDBObject("$pull", update));
票数 12
EN

Stack Overflow用户

发布于 2014-03-22 21:17:47

remove方法从模板中删除文档。如果要从数组中删除项,则必须使用pull。就像这样

代码语言:javascript
复制
MongoOperations mongoOperations = mongoConfiguration.getMongoTemplate();
Query query = new Query(where("_id").is(docID).and("itemList.itemID").is(itemID));
Update update = new Update().pull("itemList", new BasicDBObject("itemID", "1"));
mongoOperations.updateFirst(query, update, Item.class);
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10097621

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档