inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

실전 예제 3 - 다양한 연관관계 매핑

Category의 parent_id 생성 관련

691

Max H

작성한 질문수 12

1

안녕하세요, 영한쌤.

Category에서 private Category parent에 있지도  않은 parent_id를 @JoinColumn 기준으로 잡아주는 것이 너무 이상했는데 create table할 때 parent_id 필드가 만들어지더라구요.

명시적으로 만든 적이 없는 parent_id를 가지고 @JoinColumn에 이걸로 연결하라고 사용해도 오류가 나지 않을 뿐더러 심지어 parent_id가 생성되는 이유가 궁금합니다.

JPA java

답변 2

3

김영한

안녕하세요. Max H님

같은 카테고리를 계층구조(셀프 조인)로 만들기 때문에 이런 현상이 있는데요. 쉽게 설명드리기 위해 Category가 2개 있다고 가정해보겠습니다.

ParentCategory {

  @Id Long id

}

ParentCategory 테이블

- PK id

ChildCategory {

  @Id Long id

  @ManyToOne

  @JoinColumn(name = "parent_id")

  private Category parent;

}

ChildCategory 테이블

- PK id

- FK parent_id

ChildCategory 테이블은 ParentCategory 테이블과 조인을 위해 FK로 parent_id를 가지게 됩니다.

그리고 조인을 하게 되면 기본으로 ParentCategory의 PK와 조인이 됩니다.

다음을 참고해보시면 도움이 되실거에요.

https://www.inflearn.com/questions/113969

감사합니다.

0

김민지

저거 무슨소린지 잘 모르겠는데... 
category에서 변수명을 parent로 했잖아요
근데 parent에는 그냥 id만 있을뿐인데 어떻게 joincolumn을 parent_id로 하는거죠? 그냥 id여야하는거아닌가요?

0

김영한

안녕하세요. 김민지님

parent_id가 FK로 생성되기 때문입니다.

이 부분은 직접 코드로 만들에서 테스트해보시고, 생성되는 테이블을 비교해보시면 이해가 되실꺼에요.

감사합니다.

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

0

27

2

inheritance startegy 선택시 고려사항

0

22

1

Entity 동등성 비교

0

21

1

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

0

46

1

H2데이터베이스 파일 생성

0

56

2

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

0

53

2

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

0

52

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

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

0

93

2

UnsupportedOperationException 발생

0

86

3

H2 Database 연결이 안됩니다.

0

95

2

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

0

85

2

h2데이터베이스 실행오류

0

108

2

persistence.xml

0

108

2

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

0

80

1

영속성 컨텍스트

0

66

1

JPA 프록시

0

96

1

Native Query와 MyBatis

0

70

1

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

0

87

1

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

0

115

3

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

0

95

3

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

0

108

2

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

0

145

1