강의

멘토링

로드맵

Inflearn brand logo image

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

오리쉐리님의 프로필 이미지
오리쉐리

작성한 질문수

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

양방향 연관관계와 연관관계의 주인 1- 기본

질문드립니다..

작성

·

51

0

1. Member엔티티의 필드와 MEMBER 테이블의 외래키 컬럼을 매핑하고, Member테이블의 외래키(TEAM_ID)를 Team테이블의 기본키와 매핑한다.

2. member.getTeam()을 할때 MEMBER 테이블의 외래키(TEAM_ID)를 통해 TEAM테이블의 기본키를 참조하여 Team 데이터를 가지고 올 수 있다.

3. Member테이블의 외래키와 Team테이블의 기본키를 매핑해서 외래키-기본키 관계를 설정한다.

이 3가지가 각각 @JoinColumn때문인지, @ManyToOne때문인지 구분이 안되서 질문드립니다.. 각각 어느 어노테이션에 의해 동작되는것인가요??

 

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 오리쉐리님.

JPA에서 @ManyToOne@JoinColumn 어노테이션은 서로 다른 역할을 맡고 있으며, 이를 통해 테이블 간의 외래키 관계를 설정하고 객체 간의 관계를 매핑합니다.

  1. @ManyToOne

    • 이 어노테이션은 객체 간의 참조 관계를 정의합니다. 즉, Member 엔티티가 Team 엔티티를 참조할 수 있는 다대일 관계임을 나타내는 것이죠.
  2. @JoinColumn

    • 반면, 이 어노테이션은 데이터베이스 테이블의 컬럼을 명시적으로 매핑합니다. MEMBER 테이블의 TEAM_ID 컬럼이 Team 테이블의 기본 키와 어떻게 매핑되는지를 정의하게 됩니다.

질문해주신 각 항목에 대해 설명드리면:

  1. Item 1: Member 엔티티의 필드와 MEMBER 테이블의 외래키 컬럼을 매핑하는 작업은 @JoinColumn이 처리하며, 이는 데이터베이스에서 어떤 컬럼이 외래키로 매핑될지를 지정합니다.

  2. Item 2: member.getTeam() 호출 시 JPA는 @ManyToOne 관계를 사용하여 MEMBER 테이블의 TEAM_ID를 통해 TEAM 테이블의 기본 키를 참조하여 Team 엔티티를 가져옵니다.

  3. Item 3: Member 테이블의 외래키와 Team 테이블의 기본키의 외래키-기본키 관계는 @JoinColumn에 의해 구체화되며, 이는 데이터베이스 레벨의 외래키 관계 설정을 나타냅니다.

관련된 질문으로 도움이 될 만한 내용을 아래에 첨부합니다:
- @JoinColumn 애노테이션 질문 있습니다.
- JPA @Joincolumn 사용시 동작과정 문의 드립니다.

조금이나마 도움이 되었기를 바랍니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

오리쉐리님의 프로필 이미지
오리쉐리

작성한 질문수

질문하기