Spring Data Mongodb:从数组中删除字符串

问题描述 投票:0回答:1

我有一个名为pub的集合。每个文档包含一个名为cocktails的字符串数组,因此:

{"id" : "0", "name" : "My Beautiful Pub", "cocktails" : ["B52", "SexOnTheBeach", "Negroni"]}

使用Spring mongodb,我将删除每个“ SexOnTheBeach”,以便:

{"id" : "0", "name" : "My Beautiful Pub", "cocktails" : ["B52", "Negroni"]}

...我的“ pub”集合中的每个pub文档都不能包含“ SexOnTheBeach”。

我想我应该使用new Update().pull()方法,但是每次更新都不会修改我的数据库。

此mongodb查询工作正常,但我不知道如何翻译!

db.pub.update(
{ },
{ $pull: {  cocktails: "SexOnTheBeach" } },
{ multi: true })

请提前。

mongodb mongodb-query spring-data spring-data-mongodb
1个回答
0
投票

在您的@Service类中,添加:

import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Update;
import org.springframework.data.mongodb.core.query.Query;

@Autowired
private MongoTemplate mongoTemplate;

...

mongoTemplate.updateMulti(new Query(), new Update().pull("cocktails", "SexOnTheBeach"), "pub");
© www.soinside.com 2019 - 2024. All rights reserved.