inflearn logo
강의

講義

知識共有

QueryDSL 에서 중복된 데이터를 제거하고, 집계함수(count, sum 등)을 적용하는 방법에 대해 조언 구합니다!

497

henry

投稿した質問数 9

0

JOIN으로 인해서, 아래와 같이 중복되는 데이터가 발생했습니다.

id | price

1 5000
1 5000
2 6000
2 6000

따라서, Distinct를 통해 아래와 같이 중복데이터를 제외하고, groupBy(id)를 통해 id별로 price의 sum을 구해야 합니다.

id | price

1 5000
2 6000

이를 쿼리로 짜야한다면... JOIN 이후 Distinct를 적용한 서브쿼리를 From으로 조회해서 다시 groupBy(id) 를 통해 price의 sum을 구해야하는데요...

  1. 위와 같이, subquery를 from 으로 조회해야 한다면... QueryDSL 을 통해 subquery를 from으로 조회하는 문법과 관련한 내내용을 아시는 분 계실까요 ㅠ(링크라도 부탁드립니다 ㅠ)

  2. 아니면 혹시 다른 방법이 있을까요?
    - 본래 집계함(count, sum 등)수와 distinct 를 동시에 사용할 수 있는 것으로 압니다. 그런데 QueryDSL의 경우 countDistinct() 는 존재하는데... sumDisctinct()는 없는 것 같더라고요.

 

선배님들의 도움 절실히 부탁드립니다 ㅠ

스프링부트 자바 querydsl jpa

回答 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다.

죄송합니다만, 제공해드린 정보 내에서는 QueryDSL에 관한 내용을 찾을 수 없습니다. 따라서 직접적인 문법 제공이 어렵지만, 일반적인 조언을 드리겠습니다.

QueryDSL에서 중복 데이터를 제거하고 집계함수를 적용하는 방법에 대하여 몇 가지 아이디어를 제공해드리자면:

  1. 서브쿼리 사용:

    • 서브쿼리를 사용하여 JOIN 이후의 중복 결과를 먼저 distinct 처리하고, 그 결과를 바탕으로 외부 쿼리에서 groupBy와 함께 집계함수를 사용하는 방법입니다.
    • 일반적으로는 JPAQueryFactory를 통해 select, from, where 등을 조합하여 서브쿼리를 구성할 수 있습니다.
  2. 집계 함수와 함께 Distinct 사용하기:

    • countDistinct처럼 존재하는 경우가 있지만, sumDistinct과 같이 특정 집계함수에 대한 Distinct 버전이 없는 경우가 있습니다.
    • 이 경우, 서브쿼리나 조건식 내에서 별도의 로직을 구성하여 집계 전에 중복을 제거하는 전처리가 필요할 수 있습니다.
  3. Querydsl의 고급 기능 활용:

    • Querydsl은 복잡한 쿼리를 구성할 수 있는 다양한 기능을 제공합니다. 공식 문서 및 커뮤니티에서 제공하는 예제와 가이드를 참조하여, 특정 경우에 맞는 쿼리 구성 방법을 찾는 것이 좋습니다.

성능 상의 이슈도 고려해야 합니다. 서브쿼리 사용은 간혹 성능 저하를 일으킬 수 있으므로, 가능한 경우 다른 최적화 방법을 함께 고려하는 것이 좋습니다.

마지막으로, 실제 구현 상세 방법은 사용 중인 데이터베이스와 Querydsl 버전, 그리고 프로젝트의 특성에 따라 달라질 수 있으므로, 구체적인 문법과 예제 코드는 Querydsl의 공식 문서나 관련 커뮤니티, StackOverflow 등에서 검색해보시는 것을 추천드립니다.

안녕하세요 치킨 디도스 이벤트 보고 흉내내보려 들어왔습니다..

0

20

1

join에대해 질문드립니다.

0

20

1

코드 질문

0

26

1

To-Do App

0

27

1

twitterdb 연결이 안돼요

1

30

2

@JsonIgnore 이후 Internal Server Error가 발생하지 않습니다.

0

33

2

changeTeam 메서드 질문

0

35

1

테스트 관련 질문!

0

57

2

안녕하세요 질문있습니다.

0

46

2

application.properties가 적용되지 않아요

1

71

3

새 프로젝트 속 제너레이터에 SpringBoot가 없습니다.

0

54

2

설정 정보 없이 임베디드 데이터베이스 생성

0

41

1

OrderServiceTest 상문주문 테스트 시 update 쿼리 문의

0

41

1

N+1 관련해서 질문있습니다.

0

97

3

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

0

56

2

inheritance startegy 선택시 고려사항

0

41

1

Entity 동등성 비교

0

44

1

패키지 구분에 대해 궁금한게 있습니다

0

51

2

스프링부트 서버 에러나요

0

37

1

RepositoryTest의 패키지 위치가 domain인 이유

0

60

2

도메인 모델에서 관계와 규칙을 구분하는 방법

0

85

2

16 강의 메세지 retryCount의 의도

0

46

2

JPA Repository 질문이 있습니다!

1

58

2

페이지네이션 처리를 쿼리에서 하는 방식 질문

1

50

1