영속성 전이
- 특정 엔티티를 영속 상태로 만들 때 연관된 엔티티도 함께 영속 상태로 만들도 싶을 때 사용한다.
- 영속성 전이는 연관관계를 매핑하는 것과 아무 관련이 없음
- 엔티티를 영속화할 때 연관된 엔티티도 함께 영속화하는 편리함 을 제공할 뿐이다.
- 아래와 같이 설정하면 부모 엔티티를 저장할 때 자식 엔티티도 함께 저장.
- 코드 예시
Child child1 = new Child();
Child child1 = new Child();
Parent parent = new Parent();
parent.addChild(child1);
parent.addChild(child2);
em.persist(parent);
em.persist(child1);
em.persist(child2);
- 위와 같이 child에 대해서도 persist를 2번 해줘야한다. -> 번거롭다.
- 이런경우 아래와 같이
cascade=CascadeType.PERSIST
를 설정해 줄 수 있다.
@OneToMany(mappedBy="parent", cascade=CascadeType.PERSIST)
private List<Child> childList = new ArrayList<>()
- parent 객체가 가지고 있는 childList 에 Child 객체가 담기면 parent 객체가 영속성 컨텍스트에 저장될때 같이 저장된다.
Child child1 = new Child();
Child child1 = new Child();
Parent parent = new Parent();
parent.addChild(child1);
parent.addChild(child2);
em.persist(parent);
- 그렇게 되면 아래와 같이 parent에 대해서만 persist 하면된다.
CASCADE의 종류
-ALL: 모두 적용
PERSIST: 영속
REMOVE: 삭제
- MERGE: 병합
- REFRESH: REFRESH
- DETACH: DETACH
고아 객체
고아 객체 제거: 부모 엔티티와 연관관계가 끊어진 자식 엔티티 를 자동으로 삭제
orphanRemoval = true
Parent parent1 = em.find(Parent.class, id);
parent1.getChildren().remove(0);
- 위의 코드를 보면 현재 부모에 있는 childList 에서 첫번째 Child 객체를 지웠다. -> 하지만 Child 테이블에는 Child 객체가 남아있다. -> 이런경우에 Child 테이블에 해당 Child 객체를 지우는 쿼리가 나간다.
- 참조가 제거된 엔티티는 다른 곳에서 참조하지 않는 고아 객체로 보고 삭제하는 기능하다.
참조하는 곳이 하나일 때 사용해야함!
- 특정엔티티가개인소유할때사용 -> parent 만 child 를 관리할때 -> 다른 곳에서 child를 참조하고있으면 안된다.
- @OneToOne, @OneToMany만 가능
- 개념적으로 부모를 제거하면 자식은 고아가 된다. -> 부모를 제거할 때 자식도 함께 제거된다. -> 예를들어 parent 객체 자체를 지우면 그안에 있는 childList 도 지워지고 그렇게 되면 orphanRemoval = true 이기 때문에 Child 테이블에서 해당 Child들도 다 지워진다. -> 이것은 마치
CascadeType.REMOVE
처럼 동작한다.
영속성 전이 + 고아 객체, 생명주기
CascadeType.ALL + orphanRemovel=true
- 스스로 생명주기를 관리하는 엔티티는 em.persist()로 영속화, em.remove()로 제거한다.
- 두 옵션을 모두 활성화 하면
부모 엔티티를 통해서 자식의 생명 주기를 관리
할 수 있다. - 도메인 주도 설계(DDD)의 Aggregate Root개념을 구현할 때 유용하다.
REFERENCES
- 김영한님의 자바 ORM 표준 JPA 프로그래밍
'Spring Jpa' 카테고리의 다른 글
조회 성능 최적화 (0) | 2022.02.27 |
---|---|
값타입 (0) | 2022.02.27 |
OSIV (0) | 2022.02.27 |
Spring Data Jpa (0) | 2022.02.27 |
JPA 란 (0) | 2022.02.27 |