一、基于MongoRepository开发CRUD

Spring Data提供了对mongodb数据访问的支持,我们只需要继承MongoRepository类,按照Spring Data规范就可以了
SpringData 方法定义规范
image.png

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

1、添加Repository类

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

2、编写测试类

  1. @RestController
  2. @RequestMapping("/mongo2")
  3. public class TestMongo2 {
  4. @Autowired
  5. private UserRepository userRepository;
  6. //添加
  7. @GetMapping("create")
  8. public void createUser() {
  9. User user = new User();
  10. user.setAge(20);
  11. user.setName("张三");
  12. user.setEmail("3332200@qq.com");
  13. User user1 = userRepository.save(user);
  14. }
  15. //查询所有
  16. @GetMapping("findAll")
  17. public void findUser() {
  18. List<User> userList = userRepository.findAll();
  19. System.out.println(userList);
  20. }
  21. //id查询
  22. @GetMapping("findId")
  23. public void getById() {
  24. User user = userRepository.findById("60b8d57ed539ed5b124942de").get();
  25. System.out.println(user);
  26. }
  27. //条件查询
  28. @GetMapping("findQuery")
  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. @GetMapping("findLike")
  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. @GetMapping("findPage")
  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. @GetMapping("update")
  70. public void updateUser() {
  71. User user = userRepository.findById("60b8d57ed539ed5b124942de").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. @GetMapping("delete")
  80. public void delete() {
  81. userRepository.deleteById("60b8d57ed539ed5b124942de");
  82. }
  83. }

3、SpringData方法规范

  1. @GetMapping("testMethod2")
  2. public void testMethod2() {
  3. List<User> users = userRepository.findByNameLike("张");
  4. System.out.println(users);
  5. }
  6. @GetMapping("testMethod1")
  7. public void testMethod1() {
  8. List<User> users = userRepository.findByName("张三");
  9. System.out.println(users);
  10. }
  11. @Repository
  12. public interface UserRepository extends MongoRepository<User, String> {
  13. List<User> findByName(String name);
  14. List<User> findByNameLike(String name);
  15. }