inflearn logo
강의

講義

知識共有

本当! Spring BootとJPAの活用1 - Webアプリケーション開発

エンティティクラス開発2

@JoinColumn(name="parent_id")

752

ak4686

投稿した質問数 26

1

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

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

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

[질문 내용]
@JoinColumn(name="parent_id") 의 parent_id 는 어디서의 column을 의미하는건가요?? @Column(name="parent_id") 부분이 없는거 같은데 어디서 parent_id의 컬럼이 만들어져서 이것과 join을 하는건지 궁금합니다.

JPA 웹앱 java spring-boot jpa 웹앱 spring

回答 2

4

hyunjunlee10281941

저도 궁금해서 찾아봤습니다. @JoinColumn에 명시한 이름의 컬럼이 존재하지 않는 경우, JPA가 테이블에 해당 컬럼을 직접 추가해준다고 하네요. 애플리케이션 실행 후 테이블 생성 DDL을 보면 category 테이블에 parent_id 라는 컬럼이 포함되어있는 것을 확인할 수 있습니다.

그럼 여기서 JPA가 어떻게 타입도 모르는데 이름만 가지고 컬럼을 생성할 수 있냐고 의문을 가질 수 있습니다. 어차피 @JoinColumn 어노테이션은 외래키 매핑을 하기 위한 용도이기 때문에, 생성할 컬럼은 참조하고 있는 테이블의 PK와 동일한 타입을 가져야겠죠. 이 경우에는 자기 자신인 category 테이블을 참조하고 있으므로, category_id의 타입인 bigint 타입으로 컬럼이 생성되게 됩니다.

혹여나 틀린 부분이 있다면 정정해주시면 감사하겠습니다.

1

OMG

안녕하세요. ak4686님, 공식 서포터즈 OMG입니다.
.

다음 링크의 영한님 말씀처럼 계층형 테이블 설계에 대해 별도 학습하시면 이해 되실거라 생각합니다.

 테이블 카테고리 설계를 키워드로 찾아보시고 해당 내용을 숙지하여도 강의 내용에서 이해가 안되는 부분이 있다면 다시 한번 이해한 내용과 이해되지 않은 내용을 정리하여 남겨주세요 :)


.
감사합니다.

sdk 설정 오류

0

45

2

오탈자 - @Transactional

0

53

1

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

0

49

1

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

0

62

1

MemberRepositoryTest 실행오류

0

74

1

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

1

182

2

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

1

137

2

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

0

50

1

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

0

71

1

기본 생성자

0

59

1

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

0

100

1

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

0

163

4

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

0

115

1

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

0

117

2

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

0

110

1

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

0

112

1

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

0

106

2

빌드 툴, Gradle

0

57

1

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

0

73

2

Repository에서 EntityManager 주입 방식 차이

0

87

1

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

0

70

1

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

0

80

1

dirty checking 질문드립니다.

0

80

1

동시성 관련 질문입니다

0

72

1