Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- QueryDSL
- db
- Greedy
- JPQL
- 그리디
- Android
- jpa
- AOP
- 자바
- http
- SpringBoot
- 스프링 핵심 원리
- transaction
- 백준
- 스프링 핵심 기능
- Exception
- 김영한
- 스프링
- Servlet
- 인프런
- springdatajpa
- kotlin
- 알고리즘
- Spring Boot
- java
- JDBC
- Proxy
- spring
- pointcut
- Thymeleaf
Archives
- Today
- Total
개발자되기 프로젝트
Query Method : paging 본문
이전에 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