Вопрос по java, spring, mongodb – Удалить запись из массива с помощью драйвера MongoDB-Java

9

У меня есть JSON, как:

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

Мне нужно уметь удалить одну из записей itemList. Я сделал следующее:

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

}

Этот подход не работает. Однако, когда я использовал BasicDBObject с подходом $ pull, он работает отлично! В чем разница между этими подходами!

Использование Bson похоже. Я положилanswer here HenioJR

Ваш Ответ

2   ответа
4

Метод 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);
12

Если вы хотите удалить массив в целом, я использую следующее:

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 для достижения этой цели. Echo

Похожие вопросы