inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! Querydsl

순수 JPA 리포지토리와 Querydsl

질문드립니다

182

정중한 개구리

작성한 질문수 39

0

@Test

public void paging2() {

QueryResults queryResults = queryFactory .

selectFrom(member)

.orderBy(member.username.desc()) .

offset(1)

.limit(2)

.fetchResults();

assertThat(queryResults.getTotal()).isEqualTo(4);

assertThat(queryResults.getLimit()).isEqualTo(2);

assertThat(queryResults.getOffset()).isEqualTo(1);

assertThat(queryResults.getResults().size()).isEqualTo(2); }

 

여기코드에서 queryResults 의 size 가 2인이유는 4/2인건가요? 3/2인건가요?

 

offset이 1부터 시작인데 1부터 시작해야되는건지 0부터 시작해야되는건지 잘모르겠습니다..

1부터 시작인데 왜 전체 개수가 4개인지도 의문이고

 

참고로 member에는 4개가 저장되어있습니다.

 

 

java jpa

답변 1

0

y2gcoder

안녕하세요. 정중한 개구리님, 공식 서포터즈 y2gcoder입니다.

해당 내용은 SQL에서 사용하는 offset, limit에 대한 이해가 필요합니다!

@Test

public void paging2() {

QueryResults queryResults = queryFactory .

selectFrom(member)

.orderBy(member.username.desc()) .

offset(1)

.limit(2)

.fetchResults();

assertThat(queryResults.getTotal()).isEqualTo(4);

assertThat(queryResults.getLimit()).isEqualTo(2);

assertThat(queryResults.getOffset()).isEqualTo(1);

assertThat(queryResults.getResults().size()).isEqualTo(2); }

작성해주신 코드를 보면

offset 1, limit 2 이고, 전체 레코드 수는 4개라고 말씀해주셨습니다.

offset 1이라는 뜻은 1번 인덱스의 레코드 부터 읽으라는 뜻입니다!

limit 2 는 2개의 레코드만 가져오라는 의미입니다.

offset 1과 결합하면, "두번째(1번 인덱스)의 레코드부터 2개만 가져와!"

라는 뜻입니다.

offset, limit 를 이용해 전체 레코드 중 일부만 가져오는 것을 페이징한다고 말합니다! 위의 코드대로 하면 2개당 1페이지를 이루는 셈입니다.

여기서 total은 쉽게 말씀드려서 페이징 되지 않은, offset, limit 를 제거한 쿼리의 전체 레코드 수를 뜻합니다. 이는 페이징 쿼리를 사용할 때 꼭 같이 조회하는 경우가 많습니다. 그래서 offset, limit 처리를 제외하고 4개가 반환됩니다.

그래서 하나씩 질문에 답해드리자면

 

여기코드에서 queryResults 의 size 가 2인이유는 4/2인건가요? 3/2인건가요?

=> total 4개 중 2개입니다.

offset이 1부터 시작인데 1부터 시작해야되는건지 0부터 시작해야되는건지 잘모르겠습니다..

1부터 시작인데 왜 전체 개수가 4개인지도 의문이고

=> offset 은 배열의 인덱스처럼 0번부터 시작한다고 생각해주시면 될 것 같습니다! 그러면 1번 인덱스부터 읽어야 하니 2번째 인덱스입니다. total은 위에 설명드린 내용을 읽어보시길 바랍니다.

해당 내용은 데이터베이스 선수 지식이 필요합니다! 특히 실무에서 데이터베이스 에 대한 페이징 조회는 필수라고 생각합니다. 이번 기회에 offset limit 에 대해 이해하고 넘어가시면 좋겠습니다 🙂

 

 

감사합니다.

SpringBoot 4.X에서의 Querydsl 설정

0

122

2

querydsl 오픈소스에 대한 질문

1

88

1

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

0

118

1

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

0

336

2

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

1

80

1

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

0

168

1

querydsl sum() 메서드 없어요.

0

165

2

build 디렉터리 생성

0

147

2

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

0

119

2

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

0

98

1

오타 제보 드립니다.

0

76

2

벌크 연산과 flush, clear

0

81

1

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

0

93

1

QHello import하기 문제 발생

0

152

2

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

0

73

2

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

1

203

2

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

1

207

1

querydsl 설정 문제

0

225

2

quey dsl 설정부분

0

161

2

count 쿼리 관련 질문입니다!

0

77

1

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

0

92

1

답변부탁드리겠습니다.

0

92

2

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

0

67

1

중급문법 벌크연산에서

0

84

2