为了账号安全,请及时绑定邮箱和手机立即绑定

更新子文档的所有元素,其中子文档是列表的一部分

更新子文档的所有元素,其中子文档是列表的一部分

万千封印 2023-05-17 14:35:48
我与 MongoDB 中具有不同城市地址的营销人员有文档。{  "_id": "name",  "cities": [    {      "id": "1234abc",      "city_name": "London",      "country": "England",      "addresses": [        {          "Home": "Unit 14 Edgar Buildings George Street"        },        {          "Office": "Studio 103 The Business Centre 61"        }      ]    },    {      "id": "1234xyz",      "city_name": "Paris",      "country": "France",      "addresses": [        {          "Home": "102  rue La Boétie"        },        {          "Office": " IMPASSE VIVALDI VAUCE"        }      ]    }  ]}我的实体类是 Person、city 和 address。如果那个人转移到另一个国家,如 Canda 并想要更新 France - Paris 子文档。{"_id": "name",{      "id": "1234xyz",      "city_name": "Toronto",      "country": "Canada",      "addresses": [        {          "Home": "Toronto City Hall 100 Queen St W"        },        {          "Office": "4110 Yonge StNorth York, ON M2P 2H3"        }      ]    }}我不知道哪个 Spring Data Mongo api 可以在这里工作。我尝试使用以下代码,但没有任何更新。Update changed = new Update().pull("cities", new Query(Criteria.where("_id").is(username)));mongoTemplate.updateFirst(new Query(Criteria.where("cities._id").is(cityId)), changed, Person.class);如果我使用Update update = new Update().set("cities",city);所有子文档,则替换为一个城市
查看完整描述

3 回答

?
慕斯709654

TA贡献1840条经验 获得超5个赞

拜托,你能在这里检查一次吗?Criteria.where("cities._id").is(cityId). 在这里我觉得我们必须使用"cities.id".



查看完整回答
反对 回复 2023-05-17
?
qq_花开花谢_0

TA贡献1835条经验 获得超7个赞

现在我删除它并在列表中推送更新的文档,而不是更新子文档实体。它对我有用。通过执行 toHexString 访问对象 ID 之后。

删除操作 update.pull("cities", Query.query(Criteria.where("id").is(id.toHexString()))); mongoOperations.upsert(查询,更新,Person.class);

添加操作:update.push("cities", subdocumentEntity); mongoOperations.updateFirst(查询,更新,Person.class));


查看完整回答
反对 回复 2023-05-17
?
Smart猫小萌

TA贡献1911条经验 获得超7个赞

要删除特定的城市文档:


Update changed = new Update().pull("cities", new Query(Criteria.where("id").is(cityId)));

mongoTemplate.updateFirst(new Query(Criteria.where("_id").is(username)), changed, Person.class);

添加新城市信息:


Update update = new Update().addToSet("cities",city);


查看完整回答
反对 回复 2023-05-17
  • 3 回答
  • 0 关注
  • 126 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信