🌻 JAVA/자바 ORM 표준 JPA 프로그래밍

CascadeType.DELETE, orphanRemoval 차이점

2022. 8. 4. 14:05
반응형

CascadeType.DELETE, orphanRemoval 차이점

 

목표

CASCADE.REMOVE 와 orphanRemoval의 차이점에 대해서 알아보겠습니다.

테스트용 엔티티

public class Parent {
	@OneToMany(mappedBy = "parent")
    private List<Child> children = new ArrayList<>();
}

public class Child {
	@ManyToOne
    @JoinColumn(name = "PARENT_ID")
    private Parent parent; 
}

CASCADE.REMOVE

@OneToMany(mappedBy = "parent", cascade = CascadeType.REMOVE)
private List<Child> children = new ArrayList<>();
  • 상황 1. children.remove(child)
    • 이때, child는 DETACH 상태가 된다. 즉, 고아가 된다. (부모가 없이 여전히 DB에 남아있다.)
  • 상황 2. parentRepository.delete(parent)
    • 이때, parent에 속한 모든 child는 함께 삭제된다.

orphanRemoval = true

@OneToMany(mappedBy = "parent", orphanRemoval = true)
private List<Child> children = new ArrayList<>();
  • 상황 1. children.remove(child)
    • 이때 리스트에서 제거된 child를 고아라고 인식하고 DB에서 제거한다.
  • 상황 2. parentRepository.delete(parent)
    • 이때, parent에 속한 모든 child는 함께 삭제된다.

차이점

  • 공통
    • 부모를 삭제하면 자식도 함께 삭제
  • CASCADE.REMOVE
    • 자식을 리스트에서 제거하면 DB에서 제거 안시킴.
  • orphanRemoval
    • 자식을 리스트에서 제거하면 DB에서도 제거함.

 

 

반응형
'🌻 JAVA/자바 ORM 표준 JPA 프로그래밍' 카테고리의 다른 글
  • JPA - Fetch Join이 과연 만능인가? (N+1, Pagination)
  • [JPA] N+1 문제와 해결 (feat. fetch join, EntityGraph)
  • LazyInitializationException이 나는 이유 (feat. 트랜잭션)
  • 10-3) JPQL - 중급 문법
iseunghan
iseunghan
꾸준하게 열심히..
iseunghan
iseunghan

공지사항

  • 어제보다 나은 오늘이 되기 위해 🔥
  • 분류 전체보기 (262)
    • 💐 Spring (14)
      • 개념 및 이해 (2)
      • Spring 핵심 기술 (24)
      • Spring REST API (8)
      • Spring MVC, DB 접근 기술 (7)
      • Spring Security (23)
      • Spring in Action (1)
    • 🌻 JAVA (84)
      • 자바 ORM 표준 JPA 프로그래밍 (20)
      • 알고리즘, 자료구조 (13)
      • 디자인 패턴 (7)
      • 정리정리정리 (43)
      • JUnit (1)
    • 🔖 Snippets (3)
      • Javascript (3)
    • ⚙️ Devops (22)
      • ⛏ Git (11)
      • 🐳 Docker (6)
      • 🐧 Linux (3)
      • 🌈 Jenkins (1)
      • 📬 Kafka (1)
    • 💬 ETC.. (4)
      • 💻 macOS (2)
    • 🌧️ ORM (2)
      • JPA (2)
    • 🐍 Python (3)
    • 📚 Databases (15)
      • 오라클로 배우는 데이터베이스 개론과 실습(2판) (3)
      • RealMySQL 8.0 (8)
    • 🔥 Computer Science (5)
      • 📡 네트워크 (5)
    • 🏷️ 협업 (1)
    • 📜 코딩테스트 (38)
      • BAEKJOON\수학 1, 수학 2 (8)
      • BAEKJOON\재귀 (5)
      • BAEKJOON\브루트 포스 (3)
      • BAEKJOON\정렬 (1)
      • BAEKJOON\백트래킹 (5)
      • BAEKJOON\BFS, DFS (6)
      • BAEKJOON\이분탐색 (1)
      • BAEKJOON\다이나믹 프로그래밍 (9)
      • BAEKJOON\그리디 알고리즘 (0)
    • ✨ ISEUNGHAN (1)

인기 글

최근 글

전체
오늘
어제
반응형
hELLO · Designed By 정상우.
iseunghan
CascadeType.DELETE, orphanRemoval 차이점
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.