【问题标题】:Remove an entry from array using MongoDB-Java driver使用 MongoDB-Java 驱动程序从数组中删除一个条目
【发布时间】:2012-04-23 06:24:35
【问题描述】:

我有 JSON 之类的:

{ 
    "_id" : "1",
    "_class" : "com.model.Test",
    "itemList" : [
        {
            "itemID" : "1",
            "itemName" : "Foo",
            "resources" : [ 
                { 
                    "resourceID" : "1",
                    "resourceName" : "Foo Test1"
                 }, {
                    "resourceID" : "2",
                    "resourceName" : "Foo Test2"
                 }
             ]
        }
    ]
}

我需要能够删除 itemList 的记录之一。 我做了以下事情:

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

}

这种方法行不通。 但是,当我将 BasicDBObject 与 $pull 方法一起使用时,它可以正常工作! 这些方法有什么区别!

【问题讨论】:

标签: java spring mongodb


【解决方案1】:

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

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

【讨论】:

  • 是的,这就是我使用的,但我想知道是否可以使用 Query 和 MongoOperations 来实现这一点。
【解决方案2】:

模板中的 remove 方法删除文档。如果要从数组中删除项目,则必须使用 pull。类似的东西

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

【讨论】:

    猜你喜欢
    • 2014-10-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-11-14
    • 1970-01-01
    • 2016-03-13
    相关资源
    最近更新 更多