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외래 키로 연관관계를 맺으므로 이 값을 지정하면 됩니다.
다음글에서 좀더 연관관계 어노테이션을 자세하게 살펴보겠습니다.