인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

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

새벽형개발자님의 프로필 이미지

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

페이징

JPQL Limit 문법 관련 질문

작성

·

43

0

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

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

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

[질문 내용]
현재 저희 프로젝트는 Spring Boot 3.3, Spring Data JPA, MySQL을 사용하고있습니다.

제가 강의를 통해서 JPQL에서는 Limit문법을 사용할 수 없으니 setMaxResults/setFirstResult와 같은 메소드를 통해서 페이징 처리를 해야 하는 것으로 알고 있습니다.

근데 프로젝트를 진행하다가 팀원이 limit문법을 통해서 조회를 하는 쿼리를 보았습니다.

(저희는 Spring Data JPA를 사용하고 있어 JPQL은 @Query 어노테이션을 활용하여 쿼리를 작성하고 있습니다.)

@Query("select Member m where m.nickname = "홍길동" limit 1")

위와 같은 쿼리로 데이터를 조회하는데 문제없이 애플리케이션이 돌아가는 것을 확인했습니다. Hibernate 버전이 6.x로 올라오면서 처리를 따로 해주는 걸까요? 만약 그렇다면 어느 버전에서 바뀐 것이고 어떻게 동작하길래 가능한건지 답변주시면 감사하겠습니다.

답변 1

0

인프런 AI 인턴님의 프로필 이미지

안녕하세요, 인프런 AI 인턴입니다.
새벽형개발자님께서 질문해 주셔서 감사합니다.

JPQL에서는 직접적으로 LIMIT 문을 사용할 수 없고 주로 setMaxResults()setFirstResult() 메소드를 활용하여 페이징 처리를 해야 합니다. 그러나 Hibernate 6.0 이상에서는 일부 SQL 기능이 JPQL로 이전될 수 있는 기능이 추가되었습니다. 따라서 최근에 업그레이드된 Hibernate 버전에서는 LIMIT 같은 기능이 내부적으로 지원되어 작동할 수 있습니다.

다만, 이는 Hibernate의 버전과 설정에 따라 다를 수 있으므로, 항상 최신 릴리즈 노트를 확인하고 Hibernate의 변경 사항에 주의해야 합니다. 그리고 해당 프로젝트의 의존성이 정확히 어떻게 설정되어 있는지, 어떤 JDBC 드라이버를 사용하는지 등도 고려해야 합니다. 사용 중인 Hibernate 버전의 공식 문서를 참조하여 해당 기능이 지원되는지 재확인하는 것이 좋겠습니다.

추가적인 문제가 발생하지 않도록 JPQL의 표준 문법과 호환성을 유지하면서 개발하는 것이 좋습니다. 문제가 없다 하더라도 팀과 상의 후 다양한 환경에서도 일관되게 동작하는 방식으로 쿼리를 수정하는 것을 추천드립니다.

감사합니다.

originURL: Google Doc Source