이 글은 김영한님의 자바 ORM 표준 JPA 프로그래밍 - 기본편 강의를 듣고 정리한 글입니다.
: DB 관점에서의 다중성.
대칭적이기 때문에, 애매할 때는 반대 입장을 생각해보면 된다. 팀과 회원의 관계라면, 반대로 회원과 팀을 생각해보면 된다.
@ManyToOne
@OneToMany
@OneToOne
@ManyToMany
(실무에서 쓰면 안됨!)아래 설명부터, A대B는 A가 연관관계의 주인인 관계임을 의미한다.
@Entity
public class Member {
@Id @GeneratedValue
@Column(name = "MEMBER_ID")
private Long id;
@Column(name = "USERNAME")
private String username;
@ManyToOne
@JoinColumn(name = "TEAM_ID")
private Team team; // 💡 외래키 // 양방향의 경우, mappedBy의 값
}
@Entity
public class Team {
@Id
@GeneratedValue
@Column(name = "TEAM_ID")
private Long id;
@Column(name = "NAME")
private String name;
}
@Entity
public class Team {
@Id
@GeneratedValue
@Column(name = "TEAM_ID")
private Long id;
@Column(name = "NAME")
private String name;
@OneToMany(mappedBy = "team") // Member.java의 team을 참조
private List<Member> members = new ArrayList<>();
}
@JoinColumn
을 꼭 사용해야 한다. 그렇지 않으면 조인 테이블 방식을 사용함(중간에 테이블을 하나 추가)@Entity
public class Member {
@Id @GeneratedValue
@Column(name = "MEMBER_ID")
private Long id;
@Column(name = "USERNAME")
private String username;
}
@Entity
public class Team_mapping {
@Id
@GeneratedValue
@Column(name = "TEAM_ID")
private Long id;
private String name;
@OneToMany
@JoinColumn(name = "TEAM_ID") // 반대 방향의 관리해주어야 하는 외래키
private List<Member> members = new ArrayList<>();
}
Team team = new Team();
team.setName("teamA");
team.getMembers().add(member);
@JoinColumn(insertable = false, updatable = false)
@Entity
public class Member {
@Id @GeneratedValue
@Column(name = "MEMBER_ID")
private Long id;
@Column(name = "USERNAME")
private String username;
@ManyToOne
@JoinColumn(name="TEAM_ID", insertable = false, updatable = false)
private Team team;
}
@Entity
public class Member {
@Id @GeneratedValue
@Column(name = "MEMBER_ID")
private Long id;
@Column(name = "USERNAME")
private String username;
@OneToOne
@JoinColumn(name = "LOCKER_ID")
private Locker locker; // 외래키
}
@Entity
public class Locker {
@Id @GeneratedValue
@Column(name = "LOCKER_ID")
private Long id;
private String name;
}
@Entity
public class Locker {
@Id @GeneratedValue
@Column(name = "LOCKER_ID")
private Long id;
private String name;
@OneToOne(mappedBy = "locker")
private Member_mapping member;
}
@ManyToMany
사용@JoinTable
로 연결 테이블 지정@Entity
public class Member {
@Id @GeneratedValue
@Column(name = "MEMBER_ID")
private Long id;
@Column(name = "USERNAME")
private String username;
@ManyToMany
@JoinTable(name = "MEMBER_PRODUCT") // 연결 테이블 이름
private List<Product> products = new ArrayList<>();
}
@Entity
public class Product {
@Id @GeneratedValue
@Column(name = "PRODUCT_ID")
private Long id;
private String name;
}
@Entity
public class Product {
@Id @GeneratedValue
@Column(name = "PRODUCT_ID")
private Long id;
private String name;
@ManyToMany(mappedBy = "products")
private List<Member> members = new ArrayList<>();
}
@ManyToMany
→ @OneToMany
& @ManyToOne
@Entity
public class MemberProduct { // Orders
@Id @GeneratedValue
private Long Id;
@ManyToOne
@JoinColumn(name = "MEMBER_ID")
private Member member;
@ManyToOne
@JoinColumn(name = "PRODUCT_ID")
private Product product;
// 추가적으로 데이터들을 넣을 수 있다
private int count;
private LocalDateTime orderDateTime;
// ...
}
@Entity
public class Member {
@Id @GeneratedValue
@Column(name = "MEMBER_ID")
private Long id;
@Column(name = "USERNAME")
private String username;
@OneToMany(mappedBy = "member")
private List<MemberProduct> memberProduct = new ArrayList<>();
}
@Entity
public class Product {
@Id @GeneratedValue
@Column(name = "PRODUCT_ID")
private Long id;
private String name;
@ManyToMany(mappedBy = "product")
private List<MemberProduct> memberProduct = new ArrayList<>();
}
@JoinColumn
@ManyToOne
@OneToMany
@OneToMany
에는 mappedBy
속성이 있는데, @ManyToOne
은 mappedBy
속성이 없다.