inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

@OnetoMany와 @ManytoOne

262

테케이

작성한 질문수 3

0

@OnetoMany 단방향과 @ManytoOne양방향에 대한 의문이 생겨 질문드립니다!

강의에서 1:N인경우 N쪽 엔티티에서 1쪽 엔티티를 몰라도 되고, 1쪽 엔티티에서 N을 알아야하는 경우

@OnetoMany 단방향보다 @ManytoOne양방향을 쓰는게 덜 헷갈리고  낫다는 걸 인지했습니다.

예외적으로 @OnetoMany 단방향을 써야한다면 이런 경우가 가능할지 궁금합니다.

예를들어 B엔티티: A엔티티가 1:N,  C엔티티:A엔티티가 1:N이고,  D엔티티:A엔티티가 1:N 이렇게

여러 엔티티에서 A엔티티를 가지는 상황이고, A엔티티는 B,C,D 엔티티를 알필요는 없는 상황이라고 가정했을 때

 @ManytoOne양방향 을 사용한다면 아래처럼 됩니다.

강의에서는 Team과 Member 둘만 있어서 잘 몰랐는데 만약 이런식으로 A엔티티를 가져다 쓸 엔티티가 많아지게 되니

양방향을 위해 A엔티티가 퓨어하지않다고 생각되었습니다. 이런 경우라도 @OnetoMany 단방향보다

@ManytoOne양방향을 쓰는게 더 나을까요? 장단점을 이미 다 알고있고, 스스로 결정을 해야하는데 죄송합니다 ㅠㅠ

이런 경우는 예외로 @OnetoMany 단방향을 선택할 수도 있을지 궁금합니다

아니면 위처럼 설계할 경우 A엔티티를 여러 엔티티에서 알고있으니 영속성 전이를 관리할 수 없게되는데

이런 설계자체가 잘못된 설계방법일까요 ..?ㅠㅠ

java JPA

답변 1

1

김영한

안녕하세요. 테케이님^^

이런 부분이 결국 트레이드 오프이지요.

그런데 실무에서 개발을 해보면 이런 경우라도 양방향을 푸는 것이 명확성에서 나은 선택입니다.

일대다 단방향의 가장 큰 문제는 머리속에서 외래 키를 업데이트 하는 부분입니다.

일대다에서 A 엔티티를 건들었는데, B 엔티티 테이블의 외래 키가 업데이트 되지요.

JPA에 능숙한 개발자들이라면 이 부분을 어느정도 수용할 수 있지만, 대부분 인지 부조화로 매우 어려워합니다. 특히 실무에서 테이블이 복잡해지기 시작하면 이해가 더 힘들어집니다.

엔티티와 테이블의 관계가 머리속에서 딱 그림이 안그려지는 것이지요.

결론은 선택이지만, 저는 다대일 양방향을 추천합니다.

감사합니다.

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

0

34

1

H2데이터베이스 파일 생성

0

45

2

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

0

47

2

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

0

45

1

JPQL 메소드와 락

0

47

1

Delivery @OneToOne

0

54

1

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

0

84

2

UnsupportedOperationException 발생

0

80

3

H2 Database 연결이 안됩니다.

0

86

2

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

0

77

2

h2데이터베이스 실행오류

0

103

2

persistence.xml

0

100

2

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

0

74

1

영속성 컨텍스트

0

59

1

JPA 프록시

0

86

1

Native Query와 MyBatis

0

60

1

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

0

81

1

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

0

110

3

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

0

89

3

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

0

99

2

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

0

133

1

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

0

67

1

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

0

95

1

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

1

172

2