1. 简介

spring-data-mongodb 提供了 MongoTemplate 与 MongoRepository 两种方式访问 mongodb,MongoRepository 操作简单,MongoTemplate操作灵活,我们在项目中可以灵活适用这两种方式操作 mongodb。

依赖

  1. <dependencies>
  2. <!-- mongoDB 依赖 -->
  3. <dependency>
  4. <groupId>org.springframework.boot</groupId>
  5. <artifactId>spring-boot-starter-data-mongodb</artifactId>
  6. <version>${spring-boot.version}</version>
  7. </dependency>
  8. <!-- 日期时间工具类 -->
  9. <dependency>
  10. <groupId>joda-time</groupId>
  11. <artifactId>joda-time</artifactId>
  12. <version>2.10.1</version>
  13. </dependency>
  14. </dependencies>

配置文件

  1. spring.data.mongodb.uri=mongodb://192.168.58.100:27017/yygh

数据库查看

  1. > db.User.find();
  2. { "_id" : ObjectId("61dc10dc43132b7ebb6c2179"), "name" : "yxw", "age" : 24, "email" : "1076372957@qq.com", "_class" : "com.xuwei.springboot_mongodb.entity.User" }
  3. { "_id" : ObjectId("61dc12cf9dcacf1e4858d18d"), "name" : "张三", "age" : 20, "email" : "3332200@qq.com", "_class" : "com.xuwei.springboot_mongodb.entity.User" }
  4. { "_id" : ObjectId("61dc12e020d7eb12fa067296"), "name" : "李四", "age" : 24, "email" : "3332200@qq.com", "_class" : "com.xuwei.springboot_mongodb.entity.User" }

2. 基于MongoTemplate

2.1 常用方法

  1. mongoTemplate.findAll(User.class): 查询User文档的全部数据
  2. mongoTemplate.findById(<id>, User.class): 查询User文档idid的数据
  3. mongoTemplate.find(query, User.class);: 根据query内的查询条件查询
  4. mongoTemplate.upsert(query, update, User.class): 修改
  5. mongoTemplate.remove(query, User.class): 删除
  6. mongoTemplate.insert(User): 新增
  7. Query对象
  8. 1. 创建一个query对象(用来封装所有条件对象),再创建一个criteria对象(用来构建条件)
  9. 2. 精准条件:criteria.and(“key”).is(“条件”),模糊条件:criteria.and(“key”).regex(“条件”) 封装条件:query.addCriteria(criteria)
  10. 3. 大于(创建新的criteria):Criteria gt = Criteria.where(“key”).gt(“条件”)
  11. 4. 小于(创建新的criteria):Criteria lt = Criteria.where(“key”).lt(“条件”)
  12. 5. Query.addCriteria(new Criteria().andOperator(gt,lt));
  13. 6. 一个query中只能有一个andOperator()。其参数也可以是Criteria数组。
  14. 7. 排序 query.withnew Sort(Sort.Direction.ASC, "age"). and(new Sort(Sort.Direction.DESC, "date")))

2.2 具体案例

实体类省略。

  1. @SpringBootTest
  2. public class MongodbApplicationTest {
  3. @Autowired
  4. private MongoTemplate mongoTemplate;
  5. @Test
  6. public void createUser() {
  7. User user = new User();
  8. user.setAge(25);
  9. user.setName("YXW");
  10. user.setEmail("1076372957@qq.com");
  11. User user1 = mongoTemplate.insert(user);
  12. System.out.println(user1);
  13. }
  14. @Test
  15. public void findAllUser() {
  16. // 同理findById
  17. List<User> users = mongoTemplate.findAll(User.class);
  18. System.out.println(users);
  19. }
  20. @Test
  21. public void findUserList() {
  22. Query query = new Query(
  23. Criteria.where("name").is("yxw").and("age").is(24)
  24. );
  25. List<User> users = mongoTemplate.find(query, User.class);
  26. System.out.println(users);
  27. }
  28. @Test
  29. public void findUserLikeName() {
  30. String name = "yxw";
  31. // 模糊查询,匹配规则,相当于 where name like 'yxw%'
  32. String regex = String.format("%s%s%s", "^.*", name, ".*$");
  33. Pattern pattern = Pattern.compile(regex, Pattern.CASE_INSENSITIVE);
  34. Query query = new Query(Criteria.where("name").regex(pattern));
  35. List<User> userList = mongoTemplate.find(query, User.class);
  36. System.out.println(userList);
  37. }
  38. @Test
  39. public void findUserPage() {
  40. String name = "yxw";
  41. Query query = new Query();
  42. String regex = String.format("%s%s%s", "^.*", name, ".*$");
  43. Pattern pattern = Pattern.compile(regex, Pattern.CASE_INSENSITIVE);
  44. query.addCriteria(Criteria.where("name").regex(pattern));
  45. // 分页查询
  46. int pageNumber = 1;
  47. int pageSize = 10;
  48. int totalCount = (int) mongoTemplate.count(query, User.class);
  49. List<User> userList = mongoTemplate.find(query.skip((pageNumber - 1) * pageSize).limit(pageSize), User.class);
  50. Map<String, Object> pageMap = new HashMap<>();
  51. pageMap.put("list", userList);
  52. pageMap.put("totalCount",totalCount);
  53. System.out.println(pageMap);
  54. }
  55. @Test
  56. public void updateUser() {
  57. User user = mongoTemplate.findById("5ffbfa2ac290f356edf9b5aa", User.class);
  58. user.setName("test_1");
  59. user.setAge(25);
  60. user.setEmail("493220990@qq.com");
  61. Query query = new Query(Criteria.where("_id").is(user.getId()));
  62. Update update = new Update();
  63. update.set("name", user.getName());
  64. UpdateResult result = mongoTemplate.upsert(query, update, User.class);
  65. long count = result.getModifiedCount();
  66. System.out.println(count);
  67. }
  68. @Test
  69. public void delete() {
  70. Query query = new Query(Criteria.where("_id").is("5ffbfa2ac290f356edf9b5aa"));
  71. DeleteResult result = mongoTemplate.remove(query, User.class);
  72. long count = result.getDeletedCount();
  73. System.out.println(count);
  74. }
  75. }

3. 基于MongoRepository

3.1 具体规范

Spring Data 提供了对 mongodb 数据访问的支持,我们只需要继承 MongoRepository 类,按照 Spring Data 规范就可以了。

  1. 不是随便声明的,而需要符合一定的规范。
  2. 查询方法以find | read | get开头。
  3. 涉及条件查询时,条件的属性用条件关键字连接。
  4. 要注意的是:条件属性首字母需要大写。
  5. 支持属性的级联查询,但若当前类有符合条件的属性则优先使用,而不使用级联属性,若需要使用级联属性,则属性之间使用_强制进行连接。

image.png image.png

3.2 具体案例

1、添加 repository/MongoRepository 类:

  1. @Repository
  2. public interface UserRepository extends MongoRepository<User, String> {
  3. }

2、测试类。

  1. @SpringBootTest
  2. class SpringbootMongodbApplicationTests2 {
  3. @Autowired
  4. private UserRepository userRepository;
  5. //添加
  6. @Test
  7. public void createUser() {
  8. User user = new User();
  9. user.setAge(24);
  10. user.setName("李四");
  11. user.setEmail("3332200@qq.com");
  12. User user1 = userRepository.save(user);
  13. System.out.println(user1);
  14. }
  15. //查询所有
  16. @Test
  17. public void findUser() {
  18. List<User> userList = userRepository.findAll();
  19. System.out.println(userList);
  20. }
  21. //id查询
  22. @Test
  23. public void getById() {
  24. User user = userRepository.findById("5ffbfe8197f24a07007bd6ce").get();
  25. System.out.println(user);
  26. }
  27. //条件查询
  28. @Test
  29. public void findUserList() {
  30. User user = new User();
  31. user.setName("张三");
  32. user.setAge(20);
  33. Example<User> userExample = Example.of(user);
  34. List<User> userList = userRepository.findAll(userExample);
  35. System.out.println(userList);
  36. }
  37. //模糊查询
  38. @Test
  39. public void findUsersLikeName() {
  40. //创建匹配器,即如何使用查询条件
  41. ExampleMatcher matcher = ExampleMatcher.matching() //构建对象
  42. .withStringMatcher(ExampleMatcher.StringMatcher.CONTAINING) //改变默认字符串匹配方式:模糊查询
  43. .withIgnoreCase(true); //改变默认大小写忽略方式:忽略大小写
  44. User user = new User();
  45. user.setName("三");
  46. Example<User> userExample = Example.of(user, matcher);
  47. List<User> userList = userRepository.findAll(userExample);
  48. System.out.println(userList);
  49. }
  50. //分页查询
  51. @Test
  52. public void findUsersPage() {
  53. Sort sort = Sort.by(Sort.Direction.DESC, "age");
  54. //0为第一页
  55. Pageable pageable = PageRequest.of(0, 10, sort);
  56. //创建匹配器,即如何使用查询条件
  57. ExampleMatcher matcher = ExampleMatcher.matching() //构建对象
  58. .withStringMatcher(ExampleMatcher.StringMatcher.CONTAINING) //改变默认字符串匹配方式:模糊查询
  59. .withIgnoreCase(true); //改变默认大小写忽略方式:忽略大小写
  60. User user = new User();
  61. user.setName("三");
  62. Example<User> userExample = Example.of(user, matcher);
  63. //创建实例
  64. Example<User> example = Example.of(user, matcher);
  65. Page<User> pages = userRepository.findAll(example, pageable);
  66. System.out.println(pages);
  67. }
  68. //修改
  69. @Test
  70. public void updateUser() {
  71. User user = userRepository.findById("5ffbfe8197f24a07007bd6ce").get();
  72. user.setName("张三_1");
  73. user.setAge(25);
  74. user.setEmail("883220990@qq.com");
  75. User save = userRepository.save(user);
  76. System.out.println(save);
  77. }
  78. //删除
  79. @Test
  80. public void delete() {
  81. userRepository.deleteById("5ffbfe8197f24a07007bd6ce");
  82. }
  83. }