JPQL로 페이징을 제공하지 않는 이유.
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
방언때문에 그런건가요? DB마다 메커니즘이나 사용 방법이 너무 상이해서 추상화 하기 어려운 건가요?
근데 JPQL은 다 방언 참고해서 나가지 않나요?
답변 1
0
안녕하세요. 궁금이님, 공식 서포터즈 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





