• spring MongoTemplate 更新复杂对象数据


    转自luweiwei1234

    先说下需求(我把需求简化了下),看下图。现在有很多人选了自己要上的课程,数据存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文档很多比较乱,也不详细。

    最终还是给折腾出来了。

    1. // 用到的package
    2. import org.springframework.data.mongodb.core.MongoTemplate;
    3. import org.springframework.data.mongodb.core.query.Criteria;
    4. import org.springframework.data.mongodb.core.query.Query;
    5. import org.springframework.data.mongodb.core.query.Update;
    6. // 主要代码
    7. Update update = Update.update("courses.$.name", "高等数学").set("courses.$.code", "GDSX");
    8. Query query = new Query(Criteria.where("sex").is("男").and("courses.id").is(2));
    9. WriteResult wr = mongoTemplate.updateMulti(query, update, Student.class);
    10. System.out.println("受影响的行数================>" + wr.getN());

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


  • 相关阅读:
    leetcode刷题笔记 273题 整数转换英文表示
    leetcode刷题笔记 278题 第一个错误的版本
    leetcode刷题笔记 268题 丢失的数字
    leetcode刷题笔记 264题 丑数 II
    leetcode刷题笔记 263题 丑数
    20210130日报
    20210129日报
    20210128日报
    20210127日报
    20210126日报
  • 原文地址:https://www.cnblogs.com/wtjqs/p/13189545.html
Copyright © 2020-2023  润新知