waveofmymind
기록하는 습관
waveofmymind
전체 방문자
오늘
어제
  • 분류 전체보기 (124)
    • 📝 정리 (5)
    • 🌊TIL (9)
    • 💻CS (1)
      • 자료구조 (1)
    • 📙Language (9)
      • ☕Java (6)
      • 🤖Kotlin (3)
    • 🍃Spring (28)
    • 👨🏻‍💻알고리즘 (67)
      • 프로그래머스 (59)
      • 백준 (3)
    • 👷DevOps (4)
      • 🐳Docker (2)
      • 🤵Jenkins (1)

블로그 메뉴

  • 홈
  • Spring
  • Java
  • 알고리즘

공지사항

인기 글

태그

  • til
  • Connection
  • 스프링 시큐리티
  • 스프링 부트
  • 힙
  • 트랜잭션 전파
  • 완전탐색
  • 다이나믹 프로그래밍
  • JDBC
  • kotest
  • kotlin
  • BFS
  • SpringAOP
  • mybatis
  • Spring Security
  • spring
  • AOP
  • 챗GPT
  • 트랜잭션
  • Open AI
  • 통합테스트
  • resultset
  • chat GPT
  • sql
  • 스택
  • 코틀린
  • LeetCode
  • CORS
  • 스프링
  • spring boot

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
waveofmymind

기록하는 습관

[Spring Data JPA] 페이징
🍃Spring

[Spring Data JPA] 페이징

2023. 2. 16. 11:37

페이징과 정렬 파라미터

스프링 데이터 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
    '🍃Spring' 카테고리의 다른 글
    • [Spring Boot] 스프링 부트 3 이상에서 Springdocs swagger 적용하기
    • [Spring Boot] @ResponseStatus와 ResponseEntity
    • [Spring] MapStruct 사용시 매핑이 제대로 안될 경우
    • [Spring] 트랜잭션 전파 - REQUIRES_NEW 활용하기
    waveofmymind
    waveofmymind

    티스토리툴바