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

标签 java spring mongodb

我有像这样的 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 方法一起使用时,它工作正常! 这些方法有什么区别!

最佳答案

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

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

关于java - 使用 MongoDB-Java 驱动程序从数组中删除条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10097621/

相关文章:

mongodb - 如何禁用与 MongoDB 的远程连接?

java - mongodb如何在JAVA中将_id转换为String

java - 如何在 Android API 2.2 及更高版本中使用 Renderscript?

java - 如何使用 viewpager(android) 创建动态选项卡?

java - 填充已声明的多维数组

java - 使用 spring BeanUtils 复制特定属性

mongodb - 当存在自相交时 $geoIntersects 不起作用

java - 我想在 java 中找到两个日期之间的计数,但是无论日期格式是什么,都应该接受日期

java - 用于 ElasticSearch 的 Spring Boot Micrometer 与 APM Java 代理

json - 如何在响应正文上添加额外的 header