inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 2편 - 데이터 접근 활용 기술

엔티티 설계 질문

136

김재연

작성한 질문수 22

0

JPA 엔티티 설계에 대한 질문입니다.

 

 

 

상품 엔티티가 있는데

 

상품을 구분하는 카테고리가 아래와 같이 2종류 있다고 가정하면

  1. 상품 배송 카테고리 (직접배송, 퀵배송, 일반택배배송, 픽업가능) -> 1:N 가능

  2. 상품 종류 카테고리 (명품, 의류, 전자제품 등등) -> 1:N 가능

 

 

어떻게 설계하는 게 좋을까요?

  1. 상품 Entity

=> 상품 테이블, 상품 배송 카테고리 테이블, 상품 종류 카테고리 테이블 (총 테이블 3개 생성됨)

 

 

  1. 상품 Entity

=> 상품 테이블, 상품 카테고리 테이블 (총 테이블 2개 생성됨)

spring mvc jpa querydsl spring-data-mybatis spring-jpa

답변 3

0

김영한

안녕하세요. 김재연님

비즈니스 상황에 따라 다르지만 일반적으로 배송 타입과 상품의 종류는 성격이 완전히 다르기 때문에 둘을 하나에 통합하는 것 보다는 분리하는 것이 더 나은 선택이라 생각합니다.

추가로 JPA 엔티티 설계의 경우 실전! 스프링 부트와 JPA 활용1 강의를 참고해보시면 도움이 되실거에요.

자세한 연관관계나 매핑 전략의 경우 자바 ORM 표준 JPA 프로그램 강의를 참고해주세요.

감사합니다.

1

김재연

감사합니다. ! 다른 강의도 더 공부해보겠습니다!

0

David

안녕하세요. 김재연님, 공식 서포터즈 David입니다.

각 안에 대해 질문자분께서 생각하시는 바를 질문과 함께 적어주실 수 있으실까요?

감사합니다.

0

김재연

테이블 갯수를 줄이면 쿼리가 더 단순해지닌깐 해본 해본 생각입니다.

0

인프런 AI 인턴

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

JPA 엔티티 설계에 대해 질문해 주셨네요. 상품과 관련된 여러 카테고리에 대해 어떻게 엔티티를 설계할지 논의하고 계시는군요. 두 가지 방법을 제시해 주셨고, 각각의 장단점이 있습니다.

첫 번째 방법

  • 상품 테이블
  • 상품 배송 카테고리 테이블
  • 상품 종류 카테고리 테이블

장점:
- 각 카테고리가 독립적인 엔티티로 관리되므로, 변경이나 확장 가능성이 높은 경우 유리합니다.
- 각 카테고리마다 추가적인 속성이 필요할 경우에도 대응이 용이합니다.

단점:
- 테이블이 많아져서 복잡도가 증가할 수 있고, 유지보수가 어려울 수 있습니다.

두 번째 방법

  • 상품 테이블
  • 상품 카테고리 테이블 (배송 및 종류를 한 테이블로 관리)

장점:
- 테이블 수가 줄어들어 관리가 쉬워질 수 있습니다.
- 단순한 구조이므로 이해하기 쉬울 수 있습니다.

단점:
- 카테고리의 특성에 따라 개별적인 속성이 필요한 경우 확장이 어려울 수 있습니다.
- 카테고리의 변화나 종류가 추가되는 경우 대응이 상대적으로 어려울 수 있습니다.

제언

카테고리별로 속성이 매우 다르거나 변동이 잦을 것으로 예상된다면 첫 번째 방법을, 그렇지 않고 구조를 간단히 유지하면서 속성의 변화가 많지 않은 경우라면 두 번째 방법을 선택하는 것이 좋습니다.

아래의 질문과 답변은 유사한 주제를 다루고 있어 참조하기 좋습니다:
- Query관련으로 질문이 있습니다 !!
- jpa 관련 질문 드려요

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

RepositoryTest의 패키지 위치가 domain인 이유

0

29

2

REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!

0

29

1

update()에 사용하는 setter 질문드립니다.

0

47

1

SQL 중심적 개발의 문제점에 대한 질문

0

72

1

혹시 Containing 을 안쓰신 이유가 있을까요?

0

83

2

[공유] 스프링부트 4.x 버전 mybatis 연동

0

173

1

@repository 어노테이션

0

89

3

ItemService

0

58

1

논리 커밋, 물리 커밋 질문드립니다.

0

54

1

내부 트랜잭션 커밋은 필수인가요?

0

57

1

프록시 커넥션 객체를 반환할 때 생성하는건가요?

0

54

1

Transaction readOnly 성능 개선 (김영한님의 대한 감사인사)

2

178

2

JPQL 대신 네이티브 쿼리를 사용해야 하는 경우

0

77

1

@EventListener(ApplicationReadyEvent.class) 관련

0

88

1

트랜잭션 동기화 매니저와 데이터 소스

0

76

1

DB 관련 강의 개설 계획은 없으신건가요?

0

133

2

물리 트랜잭션 과 논리트랜잭션 용어를 맞게 이해한걸까요

0

94

1

스프링 3 버전 이상 rollbackFor 변경된듯요

1

112

1

트랜잭션 전파 질문.

0

87

1

프로젝트 오픈 에러

0

126

1

외부 트랜잭션에서 isNewTransaction이 false로 나오는거에 대해 질문드립니다

0

83

2

같은 스레드를 사용하면 트랜잭션 동기화 매니저는 같은 커넥션을 반환

0

72

1

h2 인메모리 테스트중 예약어 충돌날 경우 대처방법

0

102

1

커스텀aop와 트랜잭션을 같이 사용할때 우선순위에 관한 질문

0

98

2