v3 와 v6 질문드립니다.
428
1 asked
안녕하세요 김영한님 항상 질 높은 강의 잘듣고있습니다!!
다름이 아니라 강의를 듣다보니 v3랑 v6의 차이점에 대해서 제가 생각한 부분이 맞는지 질문드립니다.
v3의 경우 중복을 제거하기 위해 distinct라는 명령어를 사용하고 v6의 경우에는 로직을 추가해서 중복을 제거했습니다. 두 가지가 실제 쿼리의 조인은 비슷할거라 생각합니다.
그렇다면 차이는
1. select 해오는 컬럼들을 선택할 수 있다? v3의 경우 전부다, v6의 경우 dto에 정의된 필드만
2. 컬렉션 값이 2개 이상이여도 사용 가능
의 차이 정도로 이해하면 될까요
Answer 2
8
안녕하세요. Juhyuk Lee님^^
먼저 질 높은 강의라는 멋진 표현으로 칭찬해주셔서 고맙습니다. ㅎㅎ
차이는 말씀하시는 내용이 맞습니다.
추가로 보충 답변을 드릴께요^^
1. v3는 엔티티를 조회한 것이고, v6은 일반적인 SQL과 같은 방식으로 원하는 데이터를 찍어서 조회한 것입니다.
2. v3는 엔티티를 조회하기 때문에 fetch join과 같은 JPA 기술의 도움을 받을 수도 있고, 그래서 많은 부분이 자동화 됩니다. 엔티티 중복도 distinct로 처리할 수 있습니다. v6은 일반적인 SQL 같은 방식으로 조회하기 때문에, 데이터를 한줄로 flat하게 조회해야 합니다. 그래서 이것을 분리할 때 수동으로 한땀한땀 분리해야 합니다. 중복 제거도 직접 해야 합니다.
3. v3는 엔티티를 한꺼번에 fetch join으로 조회하기 때문에 컬렉션 타입이 2개 이상이면 안됩니다. v6는 일반적인 SQL과 같은 방식으로 조회하기 때문에 마음껏 조회할 수 있습니다.
감사합니다^^!
강의 관련 외 질문입니다.
0
65
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
0
86
1
BeanCreationException
0
86
3
Update 후 UpdateMemberResponse 매핑할 때
0
46
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
98
2
페이징 + 검색조건 관련해서 질문드립니다.
0
70
1
Query Dsl Q파일 질문입니다.
0
81
1
루트 쿼리라는것은
0
58
1
메서드를 분리하는 기준
0
62
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
108
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
83
2
fetch join과 영속화와 OSIV의 관계
0
84
2
Distinct 사용 전 결과에 대한 의문
0
113
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
56
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
78
2
dto 필드 속 엔티티 여부
0
58
1
뷰템플릿 사용 시
0
76
2
Result 클래스 관련 질문
0
56
1
@PostConstruct 프록시 관련 질문드립니다
0
85
1
DTO 대신 Form 사용은 안되나요?
0
133
1
OSIV ON 상태일 때
0
95
1
fetch join VS fetch join 페이징 궁금증
0
179
2
양방향 연관관계 알아보는 법?
0
104
1
16강 17강 간단 정리 이게 맞을까요 ?
0
165
2

