어떤 경우에 양방향 연관관계를 사용하나요??
287
작성한 질문수 42
[질문 내용]
제가 생각하는 양방향 연관관계를 사용하는 이유는 다음과 같습니다.
1) 조회 : team.getMembers().stream ...
근데 이러면 모든 Member 들이 DB에서 불러와지니까
만약 조회해야 할 대상이 많은 경우(members가 너무많아서 페이징 처리를 해야 하는 경우) 는 양방향 연관관계를 삭제하고 그냥 JpaRepository 에서 쿼리로 페이징 쿼리를 작성해야 한다.
2) CascadeType.all 혹은 orphanRemoval true 를 위한 매개체
1번, 2번 이외에는 쓸데없는 것 맞을까요??
특히 강조한 부분의 제 생각이 맞는지 궁금합니다.
답변 1
0
안녕하세요. dionisos198님
JPA에서 성능을 최적화 하는 fetch join이라는 기술을 사용하려면 연관관계가 필수입니다.
강의 뒤에 나오는 fetch join을 공부해보시면 도움이 되실거에요.
감사합니다.
0
이미 페치조인을 학습한 상태입니다!!
단방향연관관계일때 @Query select m from Member m join fetch m.team t where t.id=:id 이런식으로 하면 성능최적화가 가능하지 않나요?
양방향연관관계를 통해 이득볼수있는 부분이 어디인가요!
1번, 2번 이라고 생각하는데 맞을까요?
0
영한 선생님의 활용 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





