inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

다대다 [N:M]

다대다 관계 까지 수업듣고 질문 드립니다. (fk를 pk설정)

632

배성환

작성한 질문수 12

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
예시로 드신 Member_Product 테이블의 관계는 주문 테이블이라고 이해가 되는데 이럴경우에는 fk 2개를 pk설정을 하면 중복된 값이 못들어와서 당연히 기본키를 하나 만들어 주는걸로 배웠는데 만약에 주문이 아니고 수강테이블처럼 중복된 값을 막아야 하는 경우에도 테이블 내에 pk를 하나더 만들어 주는게 맞을까요?

java jpa

답변 1

0

y2gcoder

안녕하세요, 배성환 님. 공식 서포터즈 y2gcoder 입니다.

학생, 강의 테이블이 있고 수강 테이블이라는 것이 필요한 상황이라고 이해했고, 그 때 어떻게 해야할지 저도 생각해봤습니다.

결론부터 말씀드리자면 수강 테이블에는 pk가 따로 필요하다고 판단했습니다.

저는 수강 테이블이 단순히 다대다 관계를 위한 매핑 테이블이 아니라고 판단했습니다. 수강 테이블은 단순히 학생 테이블과 강의 테이블의 매핑 테이블 역할만 해주는 것이 아니라 이름에서 보이듯이 수강신청날짜, 학점 등 수강 정보도 포함될 수 있다고 생각했습니다. 단순히 매핑 테이블이 아닌 부가적인 정보를 갖고 있어서 단독으로 조회할 때 사용할 수도 있기 때문에 pk가 따로 필요할 것 같습니다. 물론 이것은 제가 배성환님의 요구사항 일부분을 듣고 추측해본 것이기 때문에 다를 수도 있습니다 :)

또한 중복된 값에 대한 검사도 요즘은 애플리케이션 단에서 먼저 체크해주는 것이 일반적입니다. row를 바로 생성하지 않고, 학생이 수강신청을 하면 수강 테이블에 해당 학생이 해당 강의로 수강한 적이 있는 지에 대해 검사를 하는 로직을 보통 넣기 때문에 이 부분은 조금 커버가 가능할 것으로 보입니다.

저는 특히 중간 테이블을 기준으로 조회할 일이 많다고 판단했을 때 유지보수를 위해 pk를 추가해주는게 유지보수의 관점에서 효율적이라고 생각합니다. 이러한 개인적인 판단 하에 저는 pk를 따로 추가해줄 것 같습니다.

감사합니다.

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

54

2

inheritance startegy 선택시 고려사항

0

35

1

Entity 동등성 비교

0

37

1

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

0

64

1

H2데이터베이스 파일 생성

0

74

2

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

0

66

2

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

0

62

1

JPQL 메소드와 락

0

62

1

Delivery @OneToOne

0

69

1

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

0

104

2

UnsupportedOperationException 발생

0

96

3

H2 Database 연결이 안됩니다.

0

101

2

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

0

93

2

h2데이터베이스 실행오류

0

114

2

persistence.xml

0

119

2

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

0

87

1

영속성 컨텍스트

0

74

1

JPA 프록시

0

105

1

Native Query와 MyBatis

0

81

1

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

0

96

1

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

0

125

3

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

0

100

3

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

0

112

2

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

0

151

1