일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 자바ORM표준프로그래밍
- SpringBoot
- 무상태프로토콜
- JPA
- http
- 캐쉬가능
- hibernate.dialect
- initialDelay
- 멱등활용
- Git
- HTTP3
- 네이버 연결된 서비스
- anyMatch
- ERROR TYPE : org.apache.ibatis.binding.BindingException
- org.apache.ibatis.binding.BindingException
- @Table
- Transaction not successfully started
- 데이터베이스 방언
- HTTPMESSAGE
- RFC723x
- KAKAOLOGINAPI
- gitreset
- 네이버로그인API
- DB방언
- fixedDelay
- 매핑정보가없는필드
- 김영한JPA
- gitrevert
- Invalid bound statement (not found)
- @Entity
Archives
- Today
- Total
twocowsong
객체 관계 매핑 본문
객체만 사용한 연관관계와 테이블만 사용한 연관관계를 각각 알아보았지만 이제 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 |