inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

영속성 전이(CASCADE)와 고아 객체

어떤 경우에 양방향 연관관계를 사용하나요??

287

dionisos198

작성한 질문수 42

0



[질문 내용]

 

제가 생각하는 양방향 연관관계를 사용하는 이유는 다음과 같습니다.

 

1) 조회 : team.getMembers().stream ...

근데 이러면 모든 Member 들이 DB에서 불러와지니까

만약 조회해야 할 대상이 많은 경우(members가 너무많아서 페이징 처리를 해야 하는 경우) 는 양방향 연관관계를 삭제하고 그냥 JpaRepository 에서 쿼리로 페이징 쿼리를 작성해야 한다.

 

2) CascadeType.all 혹은 orphanRemoval true 를 위한 매개체

 

1번, 2번 이외에는 쓸데없는 것 맞을까요??

특히 강조한 부분의 제 생각이 맞는지 궁금합니다.

 

 

java jpa

답변 1

0

김영한

안녕하세요. dionisos198님

JPA에서 성능을 최적화 하는 fetch join이라는 기술을 사용하려면 연관관계가 필수입니다.

강의 뒤에 나오는 fetch join을 공부해보시면 도움이 되실거에요.

감사합니다.

0

dionisos198

이미 페치조인을 학습한 상태입니다!!

단방향연관관계일때 @Query select m from Member m join fetch m.team t where t.id=:id 이런식으로 하면 성능최적화가 가능하지 않나요?

양방향연관관계를 통해 이득볼수있는 부분이 어디인가요!

1번, 2번 이라고 생각하는데 맞을까요?

0

dionisos198

영한 선생님의 활용 1편에서

Order OrderItem Item 을 Order 와 Item 의 다대다 관계를 OrderItem 으로 풀어내셨고

Order 에는 @OneToMany 를 사용하셨고 Item 에는 OneToMany 를 사용 하지 않으셨습니다.

그 이유는 Order 에서 OrderItem 을 조회할 일이 많지만 Item 에서 OrderItem 을 조회할 일이 없기 때문에 붙이지 않으셨던 걸로 기억합니다.

그런데 만약 User Reveiw Program 이렇게 Review 를 User 와 Program 의 다대다 중간 테이블로 설정한다면

 

User 에서 내가 쓴 리뷰를 조회할 일이 있다고 하면 User 에 @OneToMany 를 붙이는게 좋을 것 같아서 쓴 적이 있습니다.

 

근데 생각해보면 user.getReview 를 실행하면 쿼리가

select review from where userid=? 이런 식으로 나갑니다.

만약 내가 리뷰를 수백 수천개를 썼다면 그 모든 리뷰에 대한 정보가 DB를 통해 조회 될 것같다고 예상했습니다.

모든 리뷰를 가져오는게 싫기 때문에 직접 페이징 쿼리를 짠다고 하면

@Query("select r from Review r where r.user.id=:userId ")

메서드명 +++++= (@Param("userId") Long userId, Pageable pageable)

이런 식으로 짤 것입니다.

 

결국 내가 쓴 리뷰를 조회할 때 @OneToMany 를 이용하지 않습니다.

 

그럼 이럴 때는 영한님은 User 에서 리뷰리스트에 대한 @OneToMany 를 지우시나요?

아니면 내비 두시고

@OneToMany(casCadeType.all)

을 활용하기 위해서 즉 user.getReviews.add(newReivew) 이런 식으로 활용하기 위해서 @OneToMany 를 냅두시는지 궁금합니다.

 

0

김영한

안녕하세요. dionisos198님

만약 select m from Member가 아니라 반대인 select t from Team을 조회해야 하는데, member와 패치 조인이 필요하다면 team -> member로의 연관관계가 필요합니다.

이런 경우에 양방향이 필요합니다.

저의 경우에는 다대일 단방향 관계를 선호하고, 이런 반대편으로의 탐색이 필요한 경우에 양방향 관계를 설정합니다.

감사합니다.

inheritance startegy 선택시 고려사항

0

11

0

Entity 동등성 비교

0

14

1

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

0

41

1

H2데이터베이스 파일 생성

0

52

2

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

0

49

2

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

0

48

1

JPQL 메소드와 락

0

53

1

Delivery @OneToOne

0

57

1

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

0

89

2

UnsupportedOperationException 발생

0

82

3

H2 Database 연결이 안됩니다.

0

89

2

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

0

82

2

h2데이터베이스 실행오류

0

105

2

persistence.xml

0

103

2

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

0

77

1

영속성 컨텍스트

0

62

1

JPA 프록시

0

90

1

Native Query와 MyBatis

0

63

1

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

0

84

1

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

0

112

3

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

0

91

3

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

0

106

2

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

0

137

1

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

0

68

1