본문 바로가기
Backend, Server/JPA

[JPA] 다양한 연관관계 매핑

by ggyongi 2021. 12. 14.
반응형

- 다중성

다대일: @ManyToOne

일대다: @OneToMany

일대일: @OneToOne

다대다: @ManyToMany

 

 

1. 다대일 N:1

- 다대일 단방향

가장 많이 사용하는 연관관계

- 다대일 양방향

외래키가 있는 쪽이 연관관계의 주인이 된다.

2. 일대다 1:N

- 일대다 단방향

• 일대다 단방향은 일대다(1:N)에서 일(1)이 연관관계의 주인
• 테이블 일대다 관계는 항상 다(N) 쪽에 외래 키가 있음
• 객체와 테이블의 차이 때문에 반대편 테이블의 외래 키를 관리하는 특이한 구조
• @JoinColumn을 꼭 사용해야 함. 그렇지 않으면 조인 테이블 방식을 사용함(중간에 테이블을 하나 추가함)

• 일대다 단방향 매핑의 단점
	• 엔티티가 관리하는 외래 키가 다른 테이블에 있음
	• 연관관계 관리를 위해 추가로 UPDATE SQL 실행
• 일대다 단방향 매핑보다는 다대일 양방향 매핑을 사용하자

사용예시

더보기
@Entity
public class Member {

    @Id @GeneratedValue
    @Column(name = "MEMBER_ID")
    private Long id;

    private String name;


    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

}

 

@Entity
public class Team {

    @Id
    @GeneratedValue
    @Column(name = "TEAM_ID")
    private Long id;

    private String name;


    @OneToMany
    @JoinColumn(name = "TEAM_ID")
    private List<Member> members = new ArrayList<>();

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public List<Member> getMembers() {
        return members;
    }

    public void setMembers(List<Member> members) {
        this.members = members;
    }
}

 

Member member = new Member();
member.setName("lukas");
em.persist(member);

Team team1 = new Team();
team1.setName("ALLSTAR");
team1.getMembers().add(member);
em.persist(team1);

** @OneToMany 밑에 @JoinColumn 꼭 넣어줘야 함.. 안넣어주면 새 테이블 생성되서 걍 골치 아파짐. 이것때문에 삽질 오래함

- 일대다 양방향

• 이런 매핑은 공식적으로 존재X 
• @JoinColumn(insertable=false, updatable=false) 
• 읽기 전용 필드를 사용해서 양방향 처럼 사용하는 방법
• 다대일 양방향을 사용하자

 

3. 일대일 1:1

일대일 관계에서는 주테이블이나 대상 테이블 중에 외래키를 자유롭게 선택 가능하다. 이때 외래키가 있는 곳이 연관관계의 주인이 된다.

 

- 주테이블에 외래키 단방향(다대일 단방향 매핑과 유사)

- 주테이블 외래키 양방향

- 대상테이블 외래키 단방향(이건 JPA에서 지원하지 않음)

- 대상 테이블 외래키 양방향(사실상 주테이블 외래키 양방향과 같음.. 대칭이므로)

 

4. 다대다 N:N

- 한계점이 명확하여 실무에서 잘 사용 안함(컬럼 추가 불가)

- N:N의 경우 N:1와 1:N으로 분해하는 방식을 주로 사용 / 이때 테이블이 추가됨

 

------------------------------------------------------------------------------

*레퍼런스 : 인프런 김영한님 강의(자바 ORM 표준 JPA 프로그래밍)

 

비전공자 네카라 신입 취업 노하우

시행착오 끝에 얻어낸 취업 노하우가 모두 담긴 전자책!

kmong.com

댓글