inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

Custom Dialect 관련 질문있습니다.

454

ruew12

작성한 질문수 1

0

안녕하세요.

저는 기본문법에서 Custom Dialect로 세팅 뒤 group_concat을 사용하는 부분을 듣고있는데요.

아래와 같은 에러가 발생해서 질문드립니다.

현재 세팅에서는 Gradle과 Postgresql 을 사용중인데요.

호출한 query는 아래와 같고,

String query = "select group_concat(m.username) From Member m";

Custom Dialect 구현체는 다음과 같습니다.

public MyPostDialect() {
super();
this.registerFunction("group_concat", new StandardSQLFunction("group_concat", new StringType()));
}

ERROR: ERROR: function group_concat(character varying) does not exist

  Hint: No function matches the given name and argument types. You might need to add explicit type casts.

  Position: 60

javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: could not extract ResultSet

at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:154)

at org.hibernate.query.internal.AbstractProducedQuery.list(AbstractProducedQuery.java:1613)

at org.hibernate.query.Query.getResultList(Query.java:165)

at jpql.JpaMain.main(JpaMain.java:41)

Caused by: org.hibernate.exception.SQLGrammarException: could not extract ResultSet

at org.hibernate.exception.internal.SQLStateConversionDelegate.convert(SQLStateConversionDelegate.java:103)

at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:42)

at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:113)

at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:99)

at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.extract(ResultSetReturnImpl.java:67)

at org.hibernate.loader.Loader.getResultSet(Loader.java:2297)

at org.hibernate.loader.Loader.executeQueryStatement(Loader.java:2050)

at org.hibernate.loader.Loader.executeQueryStatement(Loader.java:2012)

at org.hibernate.loader.Loader.doQuery(Loader.java:948)

at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:349)

at org.hibernate.loader.Loader.doList(Loader.java:2843)

at org.hibernate.loader.Loader.doList(Loader.java:2825)

at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2657)

at org.hibernate.loader.Loader.list(Loader.java:2652)

at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:506)

at org.hibernate.hql.internal.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:400)

at org.hibernate.engine.query.spi.HQLQueryPlan.performList(HQLQueryPlan.java:219)

at org.hibernate.internal.SessionImpl.list(SessionImpl.java:1414)

at org.hibernate.query.internal.AbstractProducedQuery.doList(AbstractProducedQuery.java:1636)

at org.hibernate.query.internal.AbstractProducedQuery.list(AbstractProducedQuery.java:1604)

... 2 more

Caused by: org.postgresql.util.PSQLException: ERROR: function group_concat(character varying) does not exist

  Hint: No function matches the given name and argument types. You might need to add explicit type casts.

  Position: 60

혹시 어느 부분을 수정해야되는지 알 수 있을까요 ?

객체지향쿼리언어1-기본문법 java JPA

답변 1

1

OMG

안녕하세요. ruew12님, 공식 서포터즈 OMG입니다.

첨부한 에러메시지 맨 하단 쪽을 보면 다음과 같은 에러메시지가 보입니다.

Caused by: org.postgresql.util.PSQLException: ERROR: function group_concat(character varying) does not exist

postgres에서는 group_concat이 지원하지 않기 때문에 동일한 기능을 하는 postgres의 내장함수를 찾아야 하는데 string_agg입니다.

group_concat은 default 구분자가 존재해서 따로 지정하진 않았지만 string_agg는 구분자를 지정해줘야합니다.

아래 링크에 자세히 나와있으니 참고하시길 바랍니다.

https://yahwang.github.io/posts/46

감사합니다.

0

ruew12

감사합니다!

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

55

2

inheritance startegy 선택시 고려사항

0

38

1

Entity 동등성 비교

0

40

1

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

0

65

1

H2데이터베이스 파일 생성

0

76

2

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

0

67

2

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

0

62

1

JPQL 메소드와 락

0

62

1

Delivery @OneToOne

0

70

1

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

0

104

2

UnsupportedOperationException 발생

0

97

3

H2 Database 연결이 안됩니다.

0

101

2

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

0

94

2

h2데이터베이스 실행오류

0

114

2

persistence.xml

0

119

2

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

0

87

1

영속성 컨텍스트

0

74

1

JPA 프록시

0

105

1

Native Query와 MyBatis

0

81

1

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

0

97

1

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

0

125

3

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

0

101

3

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

0

112

2

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

0

152

1