페이징과 정렬 파라미터
스프링 데이터 JPA는 다음과 같은 파라미터로 페이징과 정렬을 손쉽게 사용할 수 있다.
- Sort
- Pageable(내부에 Sort 포함)
사용시 반환 타입으로는
- Page: select 외에도 추가로 count쿼리를 하나 더 보낸다.
- Slice: 추가 count쿼리 없이 다음 페이지만 확인 가능하다(내부에서 limit에 +1개 더한 개수를 조회한다.)
- List: 추가 count 없이 결과만 반환
Page는 1부터 시작이 아니라 0부터 시작이다.
Page 파라미터의 경우 다음과 같이 사용한다.
Page page = PageRequest.of(offset, limit, Sort조건);
Count 쿼리 문제
select문에 조인이 들어갈 경우, 카운트 쿼리에도 조인이 포함되어 보내지므로 성능 이슈가 발생할 수 있다.
그것을 방지하기 위해 count쿼리를 분리할 수 있다.
@Query(value = "select m from Member m", countQuery = "select count(m.username) from Member m")
Page<Member> findMemberAllCountBy(Pageable pageable);
카운트 쿼리에는 조인이 발생할 필요가 없기 때문이다.
페이지를 유지하면서 엔티티 -> DTO
컨트롤러에 뷰로 뿌릴때에는 DTO로 변환해서 뿌려야 하므로, Page 파라미터는 손쉽게 엔티티를 DTO로 변환하는 기능을 제공한다.
Page<Member> page = memberRepository.findByAge(10,pageRequest);
Page<MemberDto> dtoPage = page.map(m->new MemberDto());
슬라이스는 내가 정한 limit보다 1을 더한 개수를 조회해서 다음 페이지의 여부를 확인 할 수 있다.
'🍃Spring' 카테고리의 다른 글
[Spring Boot] 스프링 부트 3 이상에서 Springdocs swagger 적용하기 (0) | 2023.02.19 |
---|---|
[Spring Boot] @ResponseStatus와 ResponseEntity (0) | 2023.02.18 |
[Spring] MapStruct 사용시 매핑이 제대로 안될 경우 (0) | 2023.02.14 |
[Spring] 트랜잭션 전파 - REQUIRES_NEW 활용하기 (0) | 2023.02.05 |
[Spring] 트랜잭션 전파 - 2 (0) | 2023.02.05 |