양방향 매핑
안녕하세요~
양방향 매핑을 사용하면 엔티티 간의 결합도를 높이기 때문에 가급적 단방향으로 만들면 좋다는 의견도 많은 것 같더라구요.
심지어는 양방향 매핑을 만들어야 한다면 엔티티가 아니라 id 값을 넣어서 참조를 하는게 더 좋다는 의견도 있구요.
강의에서는 양방향 매핑을 사용하셨는데 실무에서도 자주 양방향 매핑으로 설계하시나요?
사용하신다면 이러한 단점이 있지만 편의성이 더 크기 때문인가요?
답변 1
1
안녕하세요, yhwjd님!
네 맞습니다. 양방향 매핑은 기본적으로 편의성을 위해서 사용하는데요!
자연스러운 그림은 연관관계의 주인(개념 상 외래키를 관리하는 쪽)인 @ManeToOne 쪽에서만 객체 참조를 가지고 있는 것이겠지만, 도메인 로직의 편의성을 위해 양방향 매핑으로 설계하고는 합니다.
그래서 'A라는 엔티티를 통해 양방향 매핑된 다수의 B라는 엔티티를 조회하는 행위'가 의미적으로 자연스러운지, 비즈니스 로직 전개 상 이점이 있는지를 판단하여 양방향 매핑을 사용하는 것이 좋다고 보고요, 기본적으로는 지양하면서 설계합니다.
대표적인 N+1문제와 같은 문제들도 같이 고려해야 하고요.
강의 중에서도 Order와 OrderProduct는 양방향 매핑을 맺었지만, Product와 OrderProduct는 그 필요가 없었기 때문에 양방향 매핑을 맺지 않았습니다.
그리고 말씀하신 것처럼 ID 참조도 많이 사용하는데요, 저도 실무에서는 객체의 Lazy Loading 같이 자칫 고려할 게 많아지고 복잡해질 수 있는 상황을 만들지 않기 위해서 직접적인 객체 매핑 대신 간접적인 ID 참조를 선호하는 편입니다.
다만, 본 강의에서는 JPA 설계에 대한 내용이 주가 아니라 올바른 테스트를 작성하기 위한 방법에 관한 강의이기 때문에, JPA를 학습하다 보면 가장 대표적으로 접하게 되는 설계 형태에 기반을 두고 강의를 진행하였으니, 이 점 참고해 주시면 좋을 것 같아요 ㅎㅎ
감사합니다 :)
private 상수 테스트 관련 질문
0
83
1
void는 어떻게 테스트하나요..? void로 애초에 코딩하면 안되나요??
0
126
2
커버리지는 어떻게 활용하시는지 궁금합니다.
0
161
2
테스트 문서화 질문입니다
0
106
2
단위테스트 질문이 있습니다
0
96
2
컨트롤러는 모킹을 한 이유가 궁금합니다.
0
103
2
ERD 가장자리에 있는 도메인 테스트 질문
0
89
2
DTO 검증 필드에 대한 테스트 코드 작성은 어디까지?
0
135
2
OrderCreateRequest DTO에 대해서 궁금한점
0
102
2
고전파의 테스트 대역 사용 대상, 공유 의존성
0
157
2
계층 관련 질문이 있습니다.
0
139
3
'코틀린'에서는 빌더를 따로 쓰지 않는데, 이 때는 어떻게 test fixture를 만드시는지 궁금합니다
1
124
2
혹시 update 로직은 어떻게 테스트하나요? (@Setter?)
0
135
2
단위테스트와 통합테스트의 경계가 궁금합니다.
0
229
2
Service+Repository 통합테스트 관련 질문입니다.
0
150
2
OrderControllerDocsTest 작성 해봤는데요. 날짜 형식이 이상하게 나와요
0
185
2
test 용 .yml
0
91
2
throws Exception
0
80
2
카페키오스크 클래스 문의 ,,
0
89
2
Rest docs 문서용 테스트코드를 따로 작성해야 되나요?
0
174
2
테스트 코드에서 필요한 생성자
0
138
1
tearDown 순서
0
116
2
@Builder 생성자 private
0
136
2
@DisplayName gradle / intellJ
0
93
2





