我有一个名为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 })
请提前。
在您的@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");