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

준영님의 프로필 이미지
준영

작성한 질문수

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

JPQL 함수

사용자 정의 함수 방언 등록

해결된 질문

작성

·

706

1

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

[질문 내용]
사용자 정의함수를 db에 등록시켜놓은 다음에 jpql로 사용을 해보니 따로 방언을 등록하지 않아도 사용이 가능합니다.

List<String> str = em.createQuery("select create_prefix(m.username) from Member m", String.class).getResultList();

create_prefix는 직접 등록한 함수입니다.

수업에서는 방언으로 사용자 정의 함수를 등록해야지 적용이 된다고 하는데 이 경우 왜 작동되는지 알고싶습니다.

답변 2

1

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

안녕하세요. 준영님

해당 기능은 하이버네이트 6(스프링 부트 3.0)부터 들어간 것으로 확인됩니다.

(하이버네이트 5 마지막 버전에서는 오류, 하이버네이트 6.0.0에서는 성공)

그런데 이 기능에 대해서 하이버네이트 6 공식 변경 목록에서 확인이 안되네요.

(https://github.com/hibernate/hibernate-orm/blob/6.0/changelog.txt)

아마도 하이버네이트 6으로 변경할 때 JPQL(HQL) 파서를 변경했는데, 이때 함께 처리가 된 것으로 예상됩니다.

공식 자료를 찾을 수 없지만 잘 동작하므로 등록하지 않고 사용하셔도 무방할 것 같습니다. 물론 혹시라도 문제가 발생하면 등록하고 사용하시면 될 것 같아요.

감사합니다.

준영님의 프로필 이미지
준영
질문자

그렇군요 답변 달아주셔서 감사합니다.

0

안녕하세요, 인프런 AI 인턴이에요. 사용자 정의 함수를 등록하지 않고도 사용할 수 있는 이유에 대해 궁금하시군요.

JPQL(Java Persistence Query Language)은 JPA(Java Persistence API)에서 사용하는 쿼리 언어로, 데이터베이스와 관련된 작업을 수행할 때 사용됩니다.

JPQL에서 사용자 정의 함수를 등록하려면 데이터베이스 방언(Dialect)을 사용하여 해당 함수를 등록해야 합니다. 방언은 데이터베이스에 종속적인 기능을 제공하는 역할을 하며, 방언 설정에 따라 JPQL에서 사용할 수 있는 함수들이 달라집니다.

하지만, 일부 JPA 구현체(예: Hibernate)는 사용자 정의 함수 등록 없이도 일부 데이터베이스에서 제공하는 함수를 사용할 수 있도록 기본적으로 내장한 방언을 제공합니다. 따라서, 일부 데이터베이스에서는 사용자 정의 함수를 등록하지 않고도 사용할 수 있습니다.

위의 예시에서 create_prefix 함수는 직접 등록한 사용자 정의 함수이기 때문에, 데이터베이스 방언 설정에 따라 등록 여부가 필요한지 결정됩니다. 만약 해당 데이터베이스의 방언이 방언 설정에 사용자 정의 함수 등록을 필수로 요구하지 않는다면, 등록하지 않아도 작동할 수 있습니다.

하지만, 데이터베이스 방언 설정에 따라 로컬 개발환경과 운영환경 간의 차이가 발생할 수 있으므로, 사용자 정의 함수 등록은 권장되는 방법입니다. 이를 통해 운영환경에서도 일관된 동작을 보장할 수 있습니다.

더 자세한 내용은 해당 JPA 구현체의 문서나 레퍼런스를 참고하거나, JPA 관련 포럼이나 커뮤니티에서 도움을 얻을 수 있습니다. 요청하신 내용에 대한 답변으로 도움이 되었으면 좋겠습니다. 어떤 추가적인 질문이 있으신가요?

준영님의 프로필 이미지
준영

작성한 질문수

질문하기