반응형
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
- K8S
- JPA
- 기술공부
- 플러터 공부
- 카프카
- JPA 공부
- 자바공부
- 자료구조공부
- Kafka
- 스프링 공부
- 프로그래머스
- 기술면접공부
- 코테공부
- 알고리즘공부
- 스프링공부
- JPA스터디
- 스프링부트공부
- querydsl
- nestjs스터디
- DDD
- JPA예제
- Axon framework
- 코테준비
- nestjs
- 플러터 개발
- 스프링부트
- 스프링
- nestjs공부
- JPA공부
- Flutter
Archives
- Today
- Total
DevBoi
[JPA] Querydsl & Paging 본문
반응형
Querydsl 처리 중 페이징처리 관련 정리
컨트롤러
@GetMapping("/member")
@Operation(description = "회원 상세 조회")
public PageImpl<Member> getAllMember( MemberReadDto memberReadDto,PageRequest pageRequest) {
Pageable pageable = pageRequest.of();
PageImpl<Member> result = memberService.getAllMember(memberReadDto,pageable);
return result;
}
커스텀 페이징 객체 구현
package com.boiler.core.backend.member.dto.paging;
import org.springframework.data.domain.Sort;
public class PageRequest {
private int page = 1;
private int size = 10;
private Sort.Direction direction = Sort.Direction.DESC;
public void setPage(int page) {
this.page = page <= 0 ? 1 : page;
}
public void setSize(int size) {
int DEFAULT_SIZE = 10;
int MAX_SIZE = 50;
this.size = size > MAX_SIZE ? DEFAULT_SIZE : size;
}
public void setDirection(Sort.Direction direction) {
this.direction = direction;
}
public org.springframework.data.domain.PageRequest of() {
return org.springframework.data.domain.PageRequest.of(page - 1, size, direction, "create_date");
}
}
서비스
public PageImpl<Member> getAllMember(MemberReadDto memberReadDto, Pageable pageable) {
QueryResults<Member> results = queryFactory.select(member)
.from(member)
.where(
MemberQuery.eqAuthCode(memberReadDto.authCode()),
MemberQuery.eqStatus(memberReadDto.status()),
MemberQuery.eqkeyword(memberReadDto.keyword())
)
.offset(pageable.getOffset())
.limit(pageable.getPageSize())
.fetchResults();
return new PageImpl<>(results.getResults(), pageable, results.getTotal());
}
QueryDsl QueryResult 와 FetchResult 방식이 사라짐
QueryDsl 5.0 부터는 Deprecated됨...
count(*)이 복잡한 쿼리에서는 동작하지 않아서 결론은 그냥 니들이 count 쿼리로 해라 라는 입장이다
무튼 그래서 아래와 같이 카운트 쿼리를 별도로 호출하는 방식으로 변경했다.
변경된 서비스
public PageImpl<Member> getAllMember(MemberReadDto memberReadDto, Pageable pageable) {
int count = this.getAllMemberCount(memberReadDto);
List<Member> results = queryFactory.select(member)
.from(member)
.where(
MemberQuery.eqAuthCode(memberReadDto.authCode()),
MemberQuery.eqStatus(memberReadDto.status()),
MemberQuery.eqkeyword(memberReadDto.keyword())
)
.offset(pageable.getOffset())
.limit(pageable.getPageSize())
.fetch();
return new PageImpl<>(results, pageable, count);
}
public Integer getAllMemberCount(MemberReadDto memberReadDto) {
return Math.toIntExact(queryFactory
.select(member.count())
.from(member)
.where(
MemberQuery.eqAuthCode(memberReadDto.authCode()),
MemberQuery.eqStatus(memberReadDto.status()),
MemberQuery.eqkeyword(memberReadDto.keyword())
)
.fetchFirst());
}
결과
{
"content": [
{
"createDate": "2023-09-02T08:25:36.729Z",
"modifiedDate": "2023-09-02T08:25:36.729Z",
"id": 0,
"memberId": "string",
"memberPw": "string",
"memberIdImageUrl": "string",
"nickname": "string",
"name": "string",
"gender": "string",
"introduce": "string",
"birth": "string",
"phone": "string",
"address": "string",
"email": "string",
"authCode": "string",
"snsCode": "string",
"status": "string",
"memo": "string"
}
],
"pageable": {
"offset": 0,
"sort": {
"empty": true,
"unsorted": true,
"sorted": true
},
"pageNumber": 0,
"pageSize": 0,
"paged": true,
"unpaged": true
},
"last": true,
"totalPages": 0,
"totalElements": 0,
"first": true,
"size": 0,
"number": 0,
"sort": {
"empty": true,
"unsorted": true,
"sorted": true
},
"numberOfElements": 0,
"empty": true
}
반응형
'Develop > [JPA]' 카테고리의 다른 글
[JPA] 스프링 Timezone 설정 + Aws, Docker mariadb timezone설정 (0) | 2023.09.30 |
---|---|
[QueryDsl] Spring 3 버전 p6spy 적용 (0) | 2023.09.09 |
[JPA] JPAUpdateClause 사용 (0) | 2023.09.02 |
[Jpa] Querydsl build Setting (0) | 2023.09.02 |
[JPA] ElementCollection (0) | 2023.08.28 |