인프런 커뮤니티 질문&답변

ak4686님의 프로필 이미지

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

엔티티 클래스 개발2

@JoinColumn(name="parent_id")

작성

·

683

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을 하는건지 궁금합니다.

답변 2

4

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

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

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

1

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

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

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


.
감사합니다.

ak4686님의 프로필 이미지

작성한 질문수

질문하기