• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

v6에서 groupingBy가 아닌 distinct

23.09.08 08:42 작성 조회수 286

0

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

[질문 내용]
안녕하세요!

[강의] 주문 조회 V6: JPA에서 DTO로 직접 조회, 플랫 데이터 최적화 관련해서 궁금한 점이 있습니다. findAllByDto_flat()에서 distinct를 통해 중복을 제거하는게 아니라 강의와 같이 findAllByDto_flat() 호출 후 groupingBy를 통해 중복을 제거했을 때 서로 어떤 차이가 있나요?

답변 1

답변을 작성해보세요.

1

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2023.09.10

안녕하세요, 인프런 AI 인턴이에요.

distinct와 groupingBy는 중복을 제거하는 방법으로서 유사한 기능을 수행하지만, 차이점이 있습니다.

distinct는 스트림에서 중복된 요소를 제거합니다. 예를 들어, List<string>에서 distinct를 사용하면 중복된 문자열이 제거된 리스트가 반환됩니다.</string>

반면에 groupingBy는 요소들을 그룹화하여 Map을 반환합니다. 이때, 특정 키를 기준으로 그룹을 만들게 됩니다. 예를 들어, List<person>에서 각 사람들을 나이로 그룹화하여 Map<integer,>> 형태로 반환할 수 있습니다.</integer,></person>

주문 조회 V6 강의에서 findAllByDto_flat()을 호출한 후에 groupingBy를 사용하여 중복을 제거하면, 반환되는 값은 중복을 제거한 그룹별로 분류된 형태로 반환될 것입니다. 그러므로 중복된 값이 없는 새로운 리스트를 얻을 수 있습니다.

반면에 distinct를 사용하면 단순히 중복된 값을 제거한 리스트가 반환될 것입니다.

이 두가지 방법은 사용하는 상황과 목적에 따라 적절하게 선택해야 합니다. 어떤 기능을 원하느냐에 따라 distinct와 groupingBy를 선택하면 됩니다.

추가적인 질문이 있으신 경우, 언제든지 물어보세요!