inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 데이터 JPA

순수 JPA 페이징과 정렬

JPQL로 페이징을 제공하지 않는 이유.

해결된 질문

444

궁금이

작성한 질문수 49

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]
방언때문에 그런건가요? DB마다 메커니즘이나 사용 방법이 너무 상이해서 추상화 하기 어려운 건가요?

근데 JPQL은 다 방언 참고해서 나가지 않나요?

 

java spring spring-boot jpa

답변 1

0

David

안녕하세요. 궁금이님, 공식 서포터즈 David입니다.

혹시 강의 몇분몇초쯤에 그렇게 말씀하시는지 알 수 있을까요?

감사합니다.

0

궁금이

아, 그 선생님께서 말씀하신 건 아니고,

그러니까 jpql 쓰면서 select m from Member m limit :limit 이런식으로 하지 않고 따로 메소드를 제공하잖아요. 순수 궁금해서 질문해봤습니다.

따로 찾아보니 jpql은 개발자가 얻고자 하는 엔티티에 더 집중시키기 위해서? 그런 말도 있는 것 같고, GPT는 DB마다 페이징 매커니즘이나 사용법같은게 상이하기 때문에 표준화? 하는데 어려움이 있을 수도.. 라고 하는데,

어차피 jpql나갈 때는 방언 참고해서 나가지 않나? 라는 생각이 들어서요.

1

김영한

안녕하세요. 궁금이님

페이징의 경우 데이터베이스 마다 제공하는 방법이 다릅니다. 따라서 이 부분이 표준화 되어 있지 않습니다. (참고로 해당 내용은 JPA 기본편 강의의 페이징에서 설명합니다 🙂 )

JPA의 경우 그래서 메서드에 페이징 조건을 넣으면 해당 조건을 기반으로 특정 데이터베이스에 맞는 SQL을 생성하게 됩니다.

JPQL 자체에 페이징 조건을 넣을 수도 있겠지만, 이렇게 하는 것 보다는 JPQL은 좀 더 단순하게 작성하고 여기에 페이징을 상황에 따라서 넣고 뺄 수 있게 메서드를 통해 기능을 제공하는 것으로 더 유연하게 설계한 것으로 이해하시면 됩니다.

감사합니다.

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

69

1

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

107

3

MemberRepository 구현체

0

57

1

pdf 표현 질문드립니다.

0

62

1

로그가 남지 않는 문제.

0

81

1

테스트 라이브러리가 강의는 junit4가 맞나요??

0

70

2

pdf 파일과 차이점이 있는 것같은데 문제 없나요?

0

72

2

@PrePersist, @PreUpdate 호출 시점 질문드립니다.

0

91

2

Sort 인터페이스는 잘 사용 안하나요?

0

52

1

스캔대상 질문드립니다.

0

46

1

하이버네이트6에서의 최적화에 이은 질문

0

85

1

save() vs saveAndFlush DB 통신 횟수

0

53

1

순수 JPA 리포지토리 코드 수정부분

0

86

2

bulk연산 후 flush하는 이유를 모르겠어요

0

152

3

bulk insert 질문입니다.

0

178

2

교만했던 것 같아요.

0

147

1

RESTful 강의는 안하시는 건지 궁금합니다.

0

147

2

동적 테이블에 대한 질문

0

85

1

영속성 전이와 연관관계

0

130

2

강의 10:25 질문

0

74

1

단건 update 질문

0

95

2

엔티티 와 도메인의 경계

0

127

1

UsernameOnlyDto 타입 type mismatch 오류

0

119

1

Projection 개념과 데이터 전달과정에 대해 질문 있습니다.

0

136

1