设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 创业者 数据 手机
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

一文搞懂如何在Spring Boot正确中使用JPA(5)

发布时间:2019-10-18 15:34 所属栏目:21 来源:SnailClimb
导读:首先我们需要创建一个包含我们需要的 Person 信息的 DTO 对象,我们简单第将其命名为 UserDTO,用于保存和传输我们想要的信息。 @Data @NoArgsConstructor @Builder(toBuilder=true) @AllArgsConstructor publicclas

首先我们需要创建一个包含我们需要的 Person 信息的 DTO 对象,我们简单第将其命名为 UserDTO,用于保存和传输我们想要的信息。

  1. @Data 
  2. @NoArgsConstructor 
  3. @Builder(toBuilder = true) 
  4. @AllArgsConstructor 
  5. public class UserDTO { 
  6.     private String name; 
  7.     private int age; 
  8.     private String companyName; 
  9.     private String schoolName; 

下面我们就来写一个方法查询出 Person 的基本信息。

  1. /** 
  2.    * 连表查询 
  3.    */ 
  4.   @Query(value = "select new github.snailclimb.jpademo.model.dto.UserDTO(p.name,p.age,c.companyName,s.name) " + 
  5.           "from Person p left join Company c on  p.companyId=c.id " + 
  6.           "left join School s on p.schoolId=s.id " + 
  7.           "where p.id=:personId") 
  8.   Optional<UserDTO> getUserInformation(@Param("personId") Long personId); 

可以看出上面的 sql 语句和我们平时写的没啥区别,差别比较大的就是里面有一个 new 对象的操作。

3.自定义 SQL 语句连表查询并实现分页操作

假如我们要查询当前所有的人员信息并实现分页的话,你可以按照下面这种方式来做。可以看到,为了实现分页,我们在@Query注解中还添加了 countQuery 属性。

  1. @Query(value = "select new github.snailclimb.jpademo.model.dto.UserDTO(p.name,p.age,c.companyName,s.name) " + 
  2.         "from Person p left join Company c on  p.companyId=c.id " + 
  3.         "left join School s on p.schoolId=s.id ", 
  4.         countQuery = "select count(p.id) " + 
  5.                 "from Person p left join Company c on  p.companyId=c.id " + 
  6.                 "left join School s on p.schoolId=s.id ") 
  7. Page<UserDTO> getUserInformationList(Pageable pageable); 

实际使用:

  1. //分页选项 
  2. PageRequest pageRequest = PageRequest.of(0, 3, Sort.Direction.DESC, "age"); 
  3. Page<UserDTO> userInformationList = personRepository.getUserInformationList(pageRequest); 
  4. //查询结果总数 
  5. System.out.println(userInformationList.getTotalElements());// 6 
  6. //按照当前分页大小,总页数 
  7. System.out.println(userInformationList.getTotalPages());// 2 
  8. System.out.println(userInformationList.getContent()); 

4.加餐:自定以SQL语句的其他用法

下面我只介绍两种比较常用的:

IN 查询

BETWEEN 查询

当然,还有很多用法需要大家自己去实践了。

4.1 IN 查询

在 sql 语句中加入我们需要筛选出符合几个条件中的一个的情况下,可以使用 IN 查询,对应到 JPA 中也非常简单。比如下面的方法就实现了,根据名字过滤需要的人员信息。

  1. @Query(value = "select new github.snailclimb.jpademo.model.dto.UserDTO(p.name,p.age,c.companyName,s.name) " + 
  2.         "from Person p left join Company c on  p.companyId=c.id " + 
  3.         "left join School s on p.schoolId=s.id " + 
  4.         "where p.name IN :peopleList") 
  5. List<UserDTO> filterUserInfo(List peopleList); 

实际使用:

List personList=new ArrayList<>(Arrays.asList("person1","person2"));List userDTOS = personRepository.filterUserInfo(personList);

4.2 BETWEEN 查询

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读