inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바 ORM 표준 JPA 프로그래밍 - 기본편

fetch 조인 일 대 다 관게

1430

1일 3시간 공부

작성한 질문수 2

3

안녕하세요 갓영환님 강의 정말 잘듣고있습니다.  정말 좋은 강의 감사합니다!

제 궁금한 부분은 저는 fetch조인이 일 대 다 일때 데이터 뻥튀기가 일어나서 데이터 값이 중복되는 부분입니다.

 fetch조인의 특성인 연관관계 매핑된 객체를 함께 조회하는 기능 때문이라 생각하고 있는데.. 

영한님 자료인 위 표를 예를 들면 Team 컬럼 팀A와 Members 컬렉션이 fetch조인될때 팀A와 연관되는 Member 테이블 로우가2개라서 한번 조인될때마다 fetch조인의 특성으로 Member 테이블에 FK외래키 연결 컬럼 모두 가져와서 팀A관련 정보가 2번 반복되는게 맞나요? 

질문에 답변 기다리겠습니다 ! 

JPA java

답변 1

7

김영한

안녕하세요. 1일 3시간 공부님 (우와 대단하신 분이군요!!)

우선 질문하신 부분은 team -> member의 일대다 조인인데, 그림은 member -> team의 다대일 조인입니다. 그림을 반대로 해서 질문하신 것이라 생각하겠습니다.

네 맞습니다^^ team과 member를 조인하면 관계형 데이터베이스의 조인 결과는 다음과 같이 나옵니다.

SQL 조인 결과

1. teamA | 회원1

2. teamA | 회원2

3. teamB | 회원3

관계형 데이터베이스의 조인이라는 것 자체가 이렇게, 소위 뻥튀기 되어서 데이터 row가 만들어지기 때문에 JPA도 이 데이터 수에 맞추게 됩니다.

따라서 응답값도 3 row가 됩니다

그런데 teamA에는 회원1, 회원2가 소속되므로 JPA는 이것을 객체스럽게 변경해줍니다. 따라서 다음과 같이 객체 그래프(객체 연관관계)가 생성됩니다.

객체 그래프 결과

1. teamA | 회원1, 회원2

2. teamA | 회원1, 회원2

3. teamB | 회원3

여기서 사실 1,2는 완전히 동일합니다. 하지만 row수는 관계형 데이터베이스 row수에 맞추어 반환이 됩니다.

강의에서 설명하지만 여기서 불필요한 중복을 제거하려면 select distinct 옵션을 주면 됩니다. 이 옵션울 주면 JPA는 SQL에 distinct 옵션도 추가하지만, 이렇게 객체 그래프 상에서 완전히 동일한 1,2 번의 중복도 제거합니다.

따라서 select distinct JPQL을 사용하면 최종 결과는 다음과 같이 깔끔하게 받을 수 있습니다^^

1. teamA | 회원1, 회원2

2. teamB | 회원3

도움이 되셨길 바라며^^ 감사합니다.

실무 조언 관련 질문입니다.

0

41

1

H2데이터베이스 파일 생성

0

50

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

49

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

48

1

JPQL 메소드와 락

0

52

1

Delivery @OneToOne

0

57

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

89

2

UnsupportedOperationException 발생

0

82

3

H2 Database 연결이 안됩니다.

0

87

2

연관관계 매핑 질문드립니다.

0

82

2

h2데이터베이스 실행오류

0

105

2

persistence.xml

0

103

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

77

1

영속성 컨텍스트

0

62

1

JPA 프록시

0

89

1

Native Query와 MyBatis

0

63

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

82

1

임베디드 타입 예시 코드 관련 질문

0

112

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

90

3

인텔리제이 패키지 커서 단축키 질문

0

106

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

136

1

양방향 연관관계 시 연관관계 주인을 설정하는 이유

0

68

1

임베디드 타입과 MappedSuperClass의 차이점이 궁금합니다.

0

95

1

데이터베이스가 초기화되는 것 같아요

1

177

2