MySQL Dialect 커스텀 관련해서 문의드립니다. (group_concat)
2268
작성한 질문수 12
안녕하세요. 영한님 오랜만에 인사드립니다.
MySQL Dialect 중 하나인 group_concat을 추가하여 사용해야 하는 상황이라.. 다음과 같이 Custom을 만들고 프로퍼티로 해당 CustomDialect까지 등록되어 정상 동작하는 상황입니다.
public class CustomMySQL57Dialect extends MySQL57Dialect {
public CustomMySQL57Dialect() {
registerFunction("GROUP_CONCAT", new StandardSQLFunction("group_concat", StandardBasicTypes.STRING));
}
}
문제는, Native Query로는 `GROUP_CONCAT(DISTINCT xxx)` 처럼 사용이 가능하나, QueryDSL을 이용한 상황에서 해당 DISTINCT가 동작하지 않습니다.. 위와 같은 상황을 겪어보셨을 지 않을까 싶어 여쭤봅니다!
QueryDSL 코드 중 일부는 다음과 같습니다.
select(Projections.constructor(PaymentFilterConditionDTO.class, transaction.merchantMemberNo,
Expressions.stringTemplate("group_concat(DISTINCT {0})",
new CaseBuilder().when(transaction.userType.eq(UserType.LINE_PAY))
.then(transaction.transactionType.stringValue()
.concat(transaction.paymentMethod.stringValue()))
.otherwise(transaction.transactionType.stringValue().concat(transaction.paymentMethod.stringValue())
.concat(SUFFIX_AFFILIATE)))))
from(...)
where(...)
위의 QueryDSL 코드에서 DISTINCT가 제외되면 예외없이 동작하구요. DISTINCT가 있을 때는 다음과 같이 예외가 발생합니다.
- unexpected token : group_concat
- unexpected token : DISTINCT
항상 도움주셔서 다시 한 번 감사합니다.
답변 2
1
오래된 질문이지만 답변 남겨 봅니다.
예시 코드는 kotlin 입니다.
class CustomMysqlDialect : MySQL8Dialect() {
init {
/**
* queryDsl 사용시
* - Expressions.stringTemplate("group_concat_distinct({0})", {QEntity.column})
* jpql 사용시
* - GROUP_CONCAT_DISTINCT({targetColumn})
*/
registerFunction("GROUP_CONCAT_DISTINCT", SQLFunctionTemplate(StandardBasicTypes.STRING, "group_concat(distinct ?1)"))
}
}
hibernate 쿼리 로그에서는 group_concat_distinct(..) 으로 보이지만
실제 수행된 쿼리 로그 보시면 group_concat(distinct ..) 으로
원하시는 쿼리 수행 확인이 가능합니다.
1
안녕하세요. pjok1122님
아쉽지만 저도 이 부분은 잘 모르겠습니다.
네이티브 쿼리를 사용하시는 것이 좋을 것 같아요.
혹시 해결 방안을 아시는 분 있으면 답변 부탁드립니다.
실무 조언 관련 질문입니다.
0
34
1
H2데이터베이스 파일 생성
0
45
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
47
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
45
1
JPQL 메소드와 락
0
47
1
Delivery @OneToOne
0
54
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
84
2
UnsupportedOperationException 발생
0
80
3
H2 Database 연결이 안됩니다.
0
86
2
연관관계 매핑 질문드립니다.
0
77
2
h2데이터베이스 실행오류
0
103
2
persistence.xml
0
100
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
74
1
영속성 컨텍스트
0
59
1
JPA 프록시
0
86
1
Native Query와 MyBatis
0
60
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
81
1
임베디드 타입 예시 코드 관련 질문
0
110
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
89
3
인텔리제이 패키지 커서 단축키 질문
0
99
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
133
1
양방향 연관관계 시 연관관계 주인을 설정하는 이유
0
67
1
임베디드 타입과 MappedSuperClass의 차이점이 궁금합니다.
0
95
1
데이터베이스가 초기화되는 것 같아요
1
172
2





