spring MongoTemplate 更新复杂对象数据

先说下需求(我把需求简化了下),看下图。现在有很多人选了自己要上的课程,数据存mongo里,但是发现courses中id=2的【数学】,名称录入错误了,或者说id=2的数学课程,名称需要更新成“高等数学”。

   

一开始按照老套路直接去update,会报一个错。Write failed with error code 16837 and error message 'cannot use the part (......) to traverse the element......

然后网上找了很多方法去尝试,发现spring的mongoTemplate文档很多比较乱,也不详细。

最终还是给折腾出来了。

// 用到的package
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;

// 主要代码
Update update = Update.update("courses.$.name", "高等数学").set("courses.$.code", "GDSX");
Query query = new Query(Criteria.where("sex").is("男").and("courses.id").is(2));
WriteResult wr = mongoTemplate.updateMulti(query, update, Student.class);
System.out.println("受影响的行数================>" + wr.getN());

最终打印结果是受影响行数为2。更新了2条数据。更新完的数据如下图:


  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值