인프런 커뮤니티 질문&답변

kkh님의 프로필 이미지
kkh

작성한 질문수

실전! Querydsl

페이징

Slice 질문 있습니다.

작성

·

355

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오) 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오) 아니오
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오) 예

[질문 내용]
여기에 질문 내용을 남겨주세요.
 
slice 관련된 질문 이있습니다.
 
 
slice querydsl에 slice를 사용할 때 id값으로
List<Long> ids = queryFactory.select(entity.id).distinct()
            .from(entity)
            .innerJoin(menu).on(menu.store.id.eq(entity.id))
            .where(
                entity.id.lt(cursorId)
            )
            .orderBy(entity.id.desc())
            .limit(size)
            .fetch();
이렇게 id 값으로 less than 을 사용해서 중복을 제거 하는데, 만약 title 과 같이 order by 가 다양하게 들어가게 되면 중복이 가능한 title로 인해서 pagination 에서 중복 데이터가 불러와 진다고 생각 이듭니다. 이런경우 에는 어떤 식으로 구현 하면 되나요?
List<Long> ids = queryFactory.select(entity.id).distinct()
            .from(entity)
            .innerJoin(menu).on(menu.store.id.eq(entity.id))
            .where(
                entity.id.lt(eneityData.getTitle())
            )
            .orderBy(entity.title.desc())
            .limit(size)
            .fetch();

답변 1

0

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. kkh님

커서 방식 페이징방식을 조금 더 이해하실 필요가 있습니다.

구글에 커서 방식 페이징으로 검색하시고 어떤 한계점이 있는지 그리고 어떤 상황에서 사용할 수 있는지 확인해주세요.

감사합니다.

kkh님의 프로필 이미지
kkh

작성한 질문수

질문하기