v6에서 groupingBy가 아닌 distinct
481
작성한 질문수 1
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예
[질문 내용]
안녕하세요!
[강의] 주문 조회 V6: JPA에서 DTO로 직접 조회, 플랫 데이터 최적화 관련해서 궁금한 점이 있습니다. findAllByDto_flat()에서 distinct를 통해 중복을 제거하는게 아니라 강의와 같이 findAllByDto_flat() 호출 후 groupingBy를 통해 중복을 제거했을 때 서로 어떤 차이가 있나요?
답변 1
1
안녕하세요, 인프런 AI 인턴이에요.
distinct와 groupingBy는 중복을 제거하는 방법으로서 유사한 기능을 수행하지만, 차이점이 있습니다.
distinct는 스트림에서 중복된 요소를 제거합니다. 예를 들어, List
반면에 groupingBy는 요소들을 그룹화하여 Map을 반환합니다. 이때, 특정 키를 기준으로 그룹을 만들게 됩니다. 예를 들어, List
주문 조회 V6 강의에서 findAllByDto_flat()을 호출한 후에 groupingBy를 사용하여 중복을 제거하면, 반환되는 값은 중복을 제거한 그룹별로 분류된 형태로 반환될 것입니다. 그러므로 중복된 값이 없는 새로운 리스트를 얻을 수 있습니다.
반면에 distinct를 사용하면 단순히 중복된 값을 제거한 리스트가 반환될 것입니다.
이 두가지 방법은 사용하는 상황과 목적에 따라 적절하게 선택해야 합니다. 어떤 기능을 원하느냐에 따라 distinct와 groupingBy를 선택하면 됩니다.
추가적인 질문이 있으신 경우, 언제든지 물어보세요!
강의 관련 외 질문입니다.
0
66
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
0
90
1
BeanCreationException
0
89
3
Update 후 UpdateMemberResponse 매핑할 때
0
47
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
99
2
페이징 + 검색조건 관련해서 질문드립니다.
0
70
1
Query Dsl Q파일 질문입니다.
0
83
1
루트 쿼리라는것은
0
59
1
메서드를 분리하는 기준
0
63
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
110
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
85
2
fetch join과 영속화와 OSIV의 관계
0
86
2
Distinct 사용 전 결과에 대한 의문
0
113
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
57
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
78
2
dto 필드 속 엔티티 여부
0
60
1
뷰템플릿 사용 시
0
76
2
Result 클래스 관련 질문
0
56
1
@PostConstruct 프록시 관련 질문드립니다
0
86
1
DTO 대신 Form 사용은 안되나요?
0
136
1
OSIV ON 상태일 때
0
96
1
fetch join VS fetch join 페이징 궁금증
0
180
2
양방향 연관관계 알아보는 법?
0
105
1
16강 17강 간단 정리 이게 맞을까요 ?
0
165
2





