모르지 않다는 것은 아는것과 다르다.

Spring Jpa

영속성 전이 (CASCADE)

채마스 2022. 2. 27. 00:52

영속성 전이

  • 특정 엔티티를 영속 상태로 만들 때 연관된 엔티티도 함께 영속 상태로 만들도 싶을 때 사용한다.
  • 영속성 전이는 연관관계를 매핑하는 것과 아무 관련이 없음
  • 엔티티를 영속화할 때 연관된 엔티티도 함께 영속화하는 편리함 을 제공할 뿐이다.
  • 아래와 같이 설정하면 부모 엔티티를 저장할 때 자식 엔티티도 함께 저장.
  • 코드 예시
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