Web/JPA

다양한 연관관계 매핑

프로그래멍 2020. 2. 2. 15:30

다대일 @ManyToOne

일대다 @OneToMany

일대일 @OneToOne

다대다 @ManyToMany

 

* 일대다 단방향 정리

 - 객체와 테이블의 차이 때문에 반대편 테이블의 외래키를 관리하는 특이한 구조

 - JoinColumn 을 꼭 사용해야 됨 그렇지 않으면 조인테이블 방식을 사용해 중간에 테이블을 자동으로 추가시킨다

 

 - 단점

  : 엔티티가 관리하는 외래키가 다른 테이블에 있음

   연관관계 관리를 위해 추가로 update sql 실행

 

* 일대다 단방향 매핑보다 다대일 양방향 매핑을 사용하자!

 

* 일대다 양방향

 - 공식적으로 존재하지 않는 매핑

 - @JoinColumn(insertable=false, updatable=false)

    읽기 전용 필드를 사용해서 양방향처럼 사용

 - 다대일 양방향을 사용하자!


* 일대일

 - 주 테이블이나 대상 테이블 중에 외래키를 선택

 - 데이터베이스에 외래키 + 유니크 제약조건 추가

 - 다대일 단방향 매핑과 유사하다

 

* 다대다

 - 편리해 보이지만 실무에서 사용안함

 - 연결 테이블이 단순히 열결만 하고 끝나지 않고

    주문시간, 수량 같은 데이터가 들어올 수 있음

 - 연결 테이블을 엩티티로 승격 시켜  @ManyToMany -> @OneToMany, @ManyToOne 사용