inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 데이터 JPA

같은 테이블의 외래키와 복합키

해결된 질문

432

haesunghong

작성한 질문수 1

0

안녕하세요 영한님. 항상 강의 잘 듣고있습니다.

회사에서 레거시 코드를 엔티티로 변경하다보니 궁금한게 있어 문의드립니다.

첫번째 질문

혹시 복합키가 3개의 컬럼으로 되어있을 때, 2개의 컬럼이 같은 테이블과 매핑해야 된다면 어떻게 해줘야하는지 알 수 있을까요? @EmbeddedId, @IdClass 둘 다 필드명으로 매핑을 해줘야 하는데, 한 필드밖에 매핑이 안되서 여쭤봅니다.

두번째 질문

아래 키들이 전부 Enum으로 되어있다면 조인할 때 @Enumrated(STRING) 이 적용이 안되는 것 같은데 어떻게 하면 좋을지 여쭤봅니다.

예를 들어,

A의 복합키 [a, b, c] 중 [a, b]가 B와 매핑되는 외래키이고, [c]는 C와 매핑되는 외래키입니다.
* 여기서 B의 a, b는 B의 PK입니다.
* A와 B는 일대다, A와 C 또한 일대다 관계입니다.

class A {
  @Id
  @Enumerated(STRING)
  EnumType a;
  @Id
  @Enumerated(STRING)
  EnumType b;
  @Id
  @Enumerated(STRING)
  EnumType c;
}

class B {
  @Id
  @Enumerated(STRING)
  EnumType a;
  @Id
  @Enumerated(STRING)
  EnumType b;
}

class C {
  @Id
  @Enumerated(STRING)
  EnumType c;
}

@EmbeddedId 사용시

@Embeddable
public class AId implements Serializable {
   private BId b;    

   @Enumerated(STRING)
   private EnumType c;
}

@Embeddable
public class BId implements Serializable {
   @Enumerated(STRING)
   private EnumType a;

   @Enumerated(STRING)
   private EnumType b;
}

@Entity
public class A {

    @EmbeddedId
    private AId id;

    // 쿼리에서 EnumType의 숫자값이 들어갑니다.
    @ManyToOne(fetch = LAZY)
    @JoinColumns(value = {
        @JoinColumn(name = "a"),
        @JoinColumn(name = "b")
    })
    private B b;
}

 

jpa spring 스프링데이터JPA 복합키 JPA spring-boot java

답변 1

1

김영한

안녕하세요. haesunghong님

첫번째 질문

JPA 책 7.3 복합 키와 식별 관계 매핑을 참고해주세요.

두번째 질문

이 부분은 저도 정확히 잘 모르겠습니다. 혹시 아시는 분 있으면 답변 부탁드려요.

감사합니다.

0

haesunghong

넵 영한님 답변 감사합니다.

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

71

1

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

107

3

MemberRepository 구현체

0

58

1

pdf 표현 질문드립니다.

0

62

1

로그가 남지 않는 문제.

0

81

1

테스트 라이브러리가 강의는 junit4가 맞나요??

0

70

2

pdf 파일과 차이점이 있는 것같은데 문제 없나요?

0

72

2

@PrePersist, @PreUpdate 호출 시점 질문드립니다.

0

91

2

Sort 인터페이스는 잘 사용 안하나요?

0

52

1

스캔대상 질문드립니다.

0

46

1

하이버네이트6에서의 최적화에 이은 질문

0

86

1

save() vs saveAndFlush DB 통신 횟수

0

54

1

순수 JPA 리포지토리 코드 수정부분

0

86

2

bulk연산 후 flush하는 이유를 모르겠어요

0

152

3

bulk insert 질문입니다.

0

178

2

교만했던 것 같아요.

0

147

1

RESTful 강의는 안하시는 건지 궁금합니다.

0

147

2

동적 테이블에 대한 질문

0

86

1

영속성 전이와 연관관계

0

131

2

강의 10:25 질문

0

74

1

단건 update 질문

0

95

2

엔티티 와 도메인의 경계

0

127

1

UsernameOnlyDto 타입 type mismatch 오류

0

120

1

Projection 개념과 데이터 전달과정에 대해 질문 있습니다.

0

136

1