Web/JPA
다양한 연관관계 매핑
프로그래멍
2020. 2. 2. 15:30
다대일 @ManyToOne
일대다 @OneToMany
일대일 @OneToOne
다대다 @ManyToMany
* 일대다 단방향 정리
- 객체와 테이블의 차이 때문에 반대편 테이블의 외래키를 관리하는 특이한 구조
- JoinColumn 을 꼭 사용해야 됨 그렇지 않으면 조인테이블 방식을 사용해 중간에 테이블을 자동으로 추가시킨다
- 단점
: 엔티티가 관리하는 외래키가 다른 테이블에 있음
연관관계 관리를 위해 추가로 update sql 실행
* 일대다 단방향 매핑보다 다대일 양방향 매핑을 사용하자!
* 일대다 양방향
- 공식적으로 존재하지 않는 매핑
- @JoinColumn(insertable=false, updatable=false)
읽기 전용 필드를 사용해서 양방향처럼 사용
- 다대일 양방향을 사용하자!
* 일대일
- 주 테이블이나 대상 테이블 중에 외래키를 선택
- 데이터베이스에 외래키 + 유니크 제약조건 추가
- 다대일 단방향 매핑과 유사하다
* 다대다
- 편리해 보이지만 실무에서 사용안함
- 연결 테이블이 단순히 열결만 하고 끝나지 않고
주문시간, 수량 같은 데이터가 들어올 수 있음
- 연결 테이블을 엩티티로 승격 시켜 @ManyToMany -> @OneToMany, @ManyToOne 사용