inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

JPQL 함수

사용자 정의 함수 방언 등록

해결된 질문

856

준영

작성한 질문수 3

1

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

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

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

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

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

java jpa

답변 2

1

김영한

안녕하세요. 준영님

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

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

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

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

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

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

감사합니다.

2

준영

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

0

인프런 AI 인턴

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

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

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

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

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

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

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

inheritance startegy 선택시 고려사항

0

11

0

Entity 동등성 비교

0

14

1

실무 조언 관련 질문입니다.

0

41

1

H2데이터베이스 파일 생성

0

52

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

49

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

48

1

JPQL 메소드와 락

0

53

1

Delivery @OneToOne

0

57

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

89

2

UnsupportedOperationException 발생

0

82

3

H2 Database 연결이 안됩니다.

0

89

2

연관관계 매핑 질문드립니다.

0

82

2

h2데이터베이스 실행오류

0

105

2

persistence.xml

0

103

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

77

1

영속성 컨텍스트

0

62

1

JPA 프록시

0

90

1

Native Query와 MyBatis

0

63

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

84

1

임베디드 타입 예시 코드 관련 질문

0

112

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

91

3

인텔리제이 패키지 커서 단축키 질문

0

106

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

138

1

양방향 연관관계 시 연관관계 주인을 설정하는 이유

0

68

1