inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! Querydsl

스프링 데이터 페이징 활용1 - Querydsl 페이징 연동

디폴트 정렬 조건 추가하고자 하는 경우

217

유승현

작성한 질문수 44

0

페이징 쿼리를 요청 받았을 때,
디폴트로 제일 마지막에 날짜(끌올 기능도 넣고 싶어 orderAt이란 LocalDate 프로퍼티 추가)를 기준으로 디폴트를 넣고자 합니다

 

public Page<Post> getPagePostBySearch(
List<District> districts, PostSearchCondition condition, Pageable pageable){
return applyPagination(pageableWithOrderAt(pageable),
query -> query
.selectFrom(post)
.join(post.category, category).fetchJoin()
.join(post.seller, account).fetchJoin()
.join(post.district, district).fetchJoin()
.where(
defaultCond(districts),
searchCond(condition)
));
}

 

private PageRequest pageableWithOrderAt(Pageable pageable) {
List<Sort.Order> orders = pageable.getSort().get().collect(Collectors.toList());
orders.add(new Sort.Order(Sort.Direction.DESC, "orderAt"));
return PageRequest.of(pageable.getPageNumber(), pageable.getPageSize(), Sort.by(orders));
}

 

이때 이렇게 입력 받은 pagable로 부터 PageRequest를 새로 만들어 적용해 주었는데,

pagable로 부터 모든 sort를 변환해서 가져온다음에 다시 적용하는것은 비효율적인 것 같아 다른 좋은 방법을 적용하고 싶은데,

잘떠오르지 않아 질문드립니다.

 

더 좋은 방법을 적용할수 있는 힌트를 얻을 수 있을까요?

답변주시면 감사드리겠습니다.

JPA java

답변 1

1

김영한

안녕하세요. 유승현님

저도 다른 방법이 떠오르지 않네요.

혹시 더 나은 방법을 아시는 분 있으면 답변 부탁드립니다.

감사합니다.

join에대해 질문드립니다.

0

8

1

SpringBoot 4.X에서의 Querydsl 설정

0

157

2

querydsl 오픈소스에 대한 질문

1

101

1

예제에서의 카운트 쿼리에서 join문과 where문은 필요없지 않나요?

0

127

1

Querydsl 6.X버전에 대해서 어떻게 생각하시나요?

0

349

2

여러 테이블 조인하여 통계치를 구하고자 할 때 어떤 방법이 더 효율적일까요

1

86

1

fetchResults()는 더이상 권장되지 않는다는데 맞나요?

0

172

1

querydsl sum() 메서드 없어요.

0

169

2

build 디렉터리 생성

0

152

2

자바 ORM 표준 JPA 프로그래밍 - 기본편 듣고 바로 학습해도 괜찮을까요?

0

123

2

현재 Querydsl에서 from절 서브쿼리를 지원하나요?

0

99

1

오타 제보 드립니다.

0

79

2

벌크 연산과 flush, clear

0

84

1

Run As Intellij 로 변경시 Q타입 import 불가

0

95

1

QHello import하기 문제 발생

0

157

2

등록된 함수 보는법(H2Dialect) 질문

0

76

2

5.0부터 Querydsl은 향후 fetchCount() , fetchResult() 를 지원하지 않기로 결정했다고 하는데 이에 맞는 강의

1

209

2

[환경설정 PDF 부트 3.0이후 설명 질문] build.gradle에 compileQuerydsl을 정의하지 않은 상태에서 Gradle->Tasks->other->compileQuerydsl을 클릭하라고 하는 이유가 무엇인가요??

1

213

1

querydsl 설정 문제

0

228

2

quey dsl 설정부분

0

168

2

count 쿼리 관련 질문입니다!

0

79

1

stringtemplate를 이용하여 where절 검색 방법 질문 드립니다.

0

98

1

답변부탁드리겠습니다.

0

95

2

(OrderSpecifier)관련 내용 어디있을가요

0

68

1