inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

도메인 모델과 테이블 설계

Member 엔티티 - Item 엔티티 연관관계 설정

53

wonderwall09in

작성한 질문수 38

0


[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예


[질문 내용]
안녕하세요, 강의 수강 중 질문이 생겨 여쭤봅니다.

요구사항 분석을 확인하면 '상품 등록'이 있습니다.

상품 등록은 회원이 직접 상품을 등록하는 것일텐데 도메인 모델 설계 부분에서 Member 엔티티와 Item 엔티티 간 연관관계가 없는 이유가 궁금합니다.

Member 엔티티가 Item을 등록하는 기능도 있으니 Member 엔티티와 Item 엔티티 간 연관관계도 설정해주어야 하지 않나요 ?!

java spring 웹앱 spring-boot jpa

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. wonderwall09in님.

회원(Member)와 상품(Item) 간의 연관관계를 설정하는 것에 대한 고민을 하신 듯합니다. 일반적으로 JPA를 사용하여 도메인 모델을 설계할 때, 객체 간 연관관계 설계는 매우 중요한 작업입니다. 그러나 모든 관계를 객체 간 연관관계로 설정하는 것이 항상 최선은 아닐 수 있습니다.

  1. 단방향 관계의 필요성: 기본적으로 Member는 자신이 등록한 Item을 조회할 수 있지만, 모든 Item이 그 사용자를 참조할 필요는 없습니다. 데이터 조회의 효율성과 복잡성 측면에서 이러한 설계는 유리할 수 있습니다.

  2. 설계 단순화: 엔티티 간의 양방향 관계는 코드의 복잡성을 증가시킵니다. 실무에서는 필요에 따라서 관계를 단방향으로 가져가는 경우가 많습니다. 대개 Item에 Member를 참조하도록 하고, 반대는 필요 시에만 설정합니다.

  3. 연관관계 없이도 가능: Member가 등록한 Item을 찾아야 하는 경우, SQL 쿼리나 JPA의 메서드를 통해 Member ID에 기반한 Item을 조회할 수 있습니다. 따라서 꼭 도메인 모델 차원에서 연관관계를 설정하지 않아도 됩니다.

관련 주제에 대한 자세한 설명은 아래의 링크에서 확인하실 수 있습니다:

도메인 간의 연관관계를 설정할 때는 성능과 요구사항을 충분히 분석한 후에 결정하는 것이 중요합니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

OrderServiceTest 상문주문 테스트 시 update 쿼리 문의

0

27

1

sdk 설정 오류

0

63

2

오탈자 - @Transactional

0

59

1

src/test/resources 테스트 경로 문제

0

55

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

69

1

MemberRepositoryTest 실행오류

0

86

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

190

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

150

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

56

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

79

1

기본 생성자

0

65

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

106

1

멤버서비스테스트 부분에서 막힙니다.

0

171

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

122

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

128

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

117

1

24분 27초 연관관계 편의 메서드 위치

0

117

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

114

2

빌드 툴, Gradle

0

63

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

80

2

Repository에서 EntityManager 주입 방식 차이

0

96

1

롬복과 사용자 정의 setter 메서드

0

77

1

주문 목록 조회 fetch join 질문드립니다

0

89

1

dirty checking 질문드립니다.

0

86

1