Notice
Recent Posts
Recent Comments
Link
«   2024/11   »
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
Archives
Today
Total
관리 메뉴

개발자되기 프로젝트

Query Method : paging 본문

JPA

Query Method : paging

Seung__ 2021. 5. 27. 22:39

이전에 page에 관련해서 간략히 정리했던 부분이 있다.

https://bsh-developer.tistory.com/13

 

아래처럼 name이 일치하는 entity를 page로 return을 해보자.

참고로  Pageagble은 paging을 요청하는 것을 의미한다.

 Page<User> findByName(String name, Pageable pageable);
 Page<Entity타입> findByName(String name, Pageable pageable);
System.out.println("find by name with paging : " 
+ userRepository.findByName("hyun", 
		PageRequest.of(0,2, Sort.by(Sort.Order.desc("id")))).getContent());

이때 PageRequest.of(page index, size, sort)의 의미이다. index는 0부터 시작하며 보여 줄 page를 지정하는것.

마지막에 .getContent()를 통해 내부 정보를 가져올 수 있다.

where
        user0_.name=?
find by name with paging : [
	User(name=hyun, email=hyun@google.com, createdAt=2021-05-27T22:30:09.646025, 
		updatedAt=2021-05-27T22:30:09.646025, id=5), 
	User(name=hyun, email=hyun@naver.com, createdAt=2021-05-27T22:30:09.640797, 
		updatedAt=2021-05-27T22:30:09.640797, id=1)
        ]

.getContent()를 .getTotalElement()로 바꿔보자.

System.out.println("find by name with paging : " 
+ userRepository.findByName("hyun", 
PageRequest.of(0,2, Sort.by(Sort.Order.desc("id")))).getTotalElements());

결과는 아래처럼 나온다. 위에서 getContent를 했을 때 elements가 2개였는데, 그 수를 확인했다.

 

 where
        user0_.name=?
find by name with paging : 2

 

 

 

'JPA' 카테고리의 다른 글

@Entity 속성 2  (0) 2021.06.15
@Entity 기본 속성 - 1  (0) 2021.06.15
Query Method 3 : 정렬  (0) 2021.05.27
Query Method 3  (0) 2021.05.27
Query Method 활용2  (0) 2021.05.26
Comments