先说下需求(我把需求简化了下),看下图。现在有很多人选了自己要上的课程,数据存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条数据。更新完的数据如下图: