강의

멘토링

로드맵

Inflearn brand logo image

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

매콤한각설탕님의 프로필 이미지
매콤한각설탕

작성한 질문수

실전! Querydsl

집합

querydsl sum() 메서드 없어요.

작성

·

9

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]

image.png


보시다시피 sum()은 아예 없어요. NumberExpression 클래스에서 집계 함수들을 살펴보니깐 sum() 은 private로 되어있고, 나머지 sum 함수들은 내부에서 sum()을 호출해요.

image.pngimage.png

 

구글에 검색해보면 다들 sum을 쓸 수 있는 것처럼 보이던데 왜 저만 이럴까요?

그리고 sumBigInteger()는 있는데 정작 sumInteger()는 왜 없을까요?

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 매콤한각설탕님께서 Querydsl의 sum() 메서드와 관련하여 질문해 주셨네요.

Querydsl을 사용하면서 NumberExpression 클래스에서 sum() 메서드가 없다는 점에 대해 불편을 느끼셨군요. 우선, sum() 함수는 내부적으로 여러 특정 타입을 지원하는 메서드를 통해 호출되며, sumLong(), sumDouble(), sumBigDecimal(), sumBigInteger() 등을 통해 다양한 숫자 타입에 맞춰 집계 작업을 수행하도록 설계되어 있습니다.

유사한 질문과 그에 대한 답변을 찾을 수 있는 글을 몇 가지 추천드리겠습니다.

  1. QueryDSL에서 Sum과 같은 집계 함수 사용법 - 해당 게시물에서는 QueryDSL에서 집계 함수를 다룰 때의 데이터 타입을 어떻게 처리할지를 설명하고 있습니다. 특히, 어떤 데이터 타입과 연관된 이름의 메서드를 선택하여 처리할 수 있는지에 대한 언급을 확인할 수 있습니다.

  2. QueryDSL에서 Sum 메서드의 내부 작동 원리 - 개발자들이 Querydsl을 사용할 때, 각 집계 함수의 내부 작동에 대한 이해가 필요할 수 있습니다. 이 링크에서는 그 과정에서의 작동 방식과 과정을 어렴풋이 볼 수 있습니다.

앞서 말씀하신 것처럼 sumInteger()가 없는 이유는 JPA 및 데이터베이스에서의 기본적인 숫자 타입이 Long이기 때문에, int보다 더 큰 범위의 수를 안전하게 다루기 위해 Long 타입을 사용하는 것이 권장됩니다. 일반적으로 sum() 결과는 데이터베이스에서 대량의 데이터에 대한 처리를 다룰 수 있기 때문에 Long 타입이 기본입니다.

Querydsl 사용자로서 적절한 반환 타입을 선택하는 것이 중요합니다. sumLong()sumBigInteger()를 선택해 사용하는 것을 권장드립니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

매콤한각설탕님의 프로필 이미지
매콤한각설탕

작성한 질문수

질문하기