首先我们需要创建一个包含我们需要的 Person 信息的 DTO 对象,我们简单第将其命名为 UserDTO,用于保存和传输我们想要的信息。
- @Data
- @NoArgsConstructor
- @Builder(toBuilder = true)
- @AllArgsConstructor
- public class UserDTO {
- private String name;
- private int age;
- private String companyName;
- private String schoolName;
- }
下面我们就来写一个方法查询出 Person 的基本信息。
- /**
- * 连表查询
- */
- @Query(value = "select new github.snailclimb.jpademo.model.dto.UserDTO(p.name,p.age,c.companyName,s.name) " +
- "from Person p left join Company c on p.companyId=c.id " +
- "left join School s on p.schoolId=s.id " +
- "where p.id=:personId")
- Optional<UserDTO> getUserInformation(@Param("personId") Long personId);
可以看出上面的 sql 语句和我们平时写的没啥区别,差别比较大的就是里面有一个 new 对象的操作。
3.自定义 SQL 语句连表查询并实现分页操作
假如我们要查询当前所有的人员信息并实现分页的话,你可以按照下面这种方式来做。可以看到,为了实现分页,我们在@Query注解中还添加了 countQuery 属性。
- @Query(value = "select new github.snailclimb.jpademo.model.dto.UserDTO(p.name,p.age,c.companyName,s.name) " +
- "from Person p left join Company c on p.companyId=c.id " +
- "left join School s on p.schoolId=s.id ",
- countQuery = "select count(p.id) " +
- "from Person p left join Company c on p.companyId=c.id " +
- "left join School s on p.schoolId=s.id ")
- Page<UserDTO> getUserInformationList(Pageable pageable);
实际使用:
- //分页选项
- PageRequest pageRequest = PageRequest.of(0, 3, Sort.Direction.DESC, "age");
- Page<UserDTO> userInformationList = personRepository.getUserInformationList(pageRequest);
- //查询结果总数
- System.out.println(userInformationList.getTotalElements());// 6
- //按照当前分页大小,总页数
- System.out.println(userInformationList.getTotalPages());// 2
- System.out.println(userInformationList.getContent());
4.加餐:自定以SQL语句的其他用法
下面我只介绍两种比较常用的:
IN 查询
BETWEEN 查询
当然,还有很多用法需要大家自己去实践了。
4.1 IN 查询
在 sql 语句中加入我们需要筛选出符合几个条件中的一个的情况下,可以使用 IN 查询,对应到 JPA 中也非常简单。比如下面的方法就实现了,根据名字过滤需要的人员信息。
- @Query(value = "select new github.snailclimb.jpademo.model.dto.UserDTO(p.name,p.age,c.companyName,s.name) " +
- "from Person p left join Company c on p.companyId=c.id " +
- "left join School s on p.schoolId=s.id " +
- "where p.name IN :peopleList")
- List<UserDTO> filterUserInfo(List peopleList);
实际使用:
List personList=new ArrayList<>(Arrays.asList("person1","person2"));List userDTOS = personRepository.filterUserInfo(personList);
4.2 BETWEEN 查询
(编辑:ASP站长网)
|