twocowsong

객체 관계 매핑 본문

IT/JPA

객체 관계 매핑

WsCode 2022. 5. 28. 21:02

객체만 사용한 연관관계와 테이블만 사용한 연관관계를 각각 알아보았지만 이제 JPA를 사용해서 둘을 매핑해보겠습니다.

(기존 Member, Team 테이블은 똑같이 사용하겠습니다.)

public class Member {

   @Id
   @Column(name="MEMBER_ID")
   private String id;
   
   private String username;
   
   @ManyToOne // MEMBER테이블과 TEAM테이블은 N : 1 임으로 ManyToOne를 사용하여 연결
   @JoinColumn(name = "TEAM_ID")
   private Team team;
   
   // Getter, Setter...

}
public class Team {
   
   @Id
   @Column(name = "TEAM_ID")
   private String id;
   
   private String name;

   // Getter, Setter...
}

Member엔티티와 Team엔티티를 매핑했습니다.

먼저 연관관계를 확인해보겠습니다.

 

- 객체 연관관계 : 회원 객체의 Member.team 필드 사용

- 테이블 연관관계 : 회원 테이블의 Member.TEAM_ID 외래 키 컬럼을 사용

 

Member.team과 MEMBER.TEAM_ID를 매핑하는것이 연관관계 매핑입니다.

@ManyToOne
@JoinColumn(name = "TEAM_ID")
private Team team;

회원 인티티에 있는 연관관계 매핑 부분인데 연관관계를 매핑하기 위한 새로운 어노테이션이 있습니다.

 

- @ManyToOne : N : 1 관계를 매핑하기 위한 어노테이션입니다. 회원과 팀은 N : 1 관계입니다. 연관관계를 매핑할 때 이렇게 다중성을 나타내는 어노테이션을 필수로 사용해야합니다.

- @JoinColumn(name = "TEAM_ID") : 조인 컬럼은 외래 키를 매핑할 때 사용합니다. name 속성에는 매핑할 외래 키 이름을 지정합니다. 회원과 팀 테이블은 TEAM_ID외래 키로 연관관계를 맺으므로 이 값을 지정하면 됩니다.

 

다음글에서 좀더 연관관계 어노테이션을 자세하게 살펴보겠습니다.

'IT > JPA' 카테고리의 다른 글

@ManyToOne  (0) 2022.05.28
@JoinColumn  (0) 2022.05.28
테이블 연관관계  (0) 2022.05.27
순수한 객체 연관관계  (0) 2022.05.27
객체 연관관계와 테이블의 연관관계  (0) 2022.05.25