JPA를 사용해서 엔티티간의 관계를 설정할때 아래와 어노테이션을 작성하는 일이 많은데 어떤 의미를 가지고 있는지 알아보자
@OneToMany(cascade={CascadeType.REFRESH, CascadeType.MERGE}, fetch = FetchType.LAZY)
먼저 각각의 CaseType에 들어가기전에 영속성 컨텍스트와 JPA의 상태에 대한 선행지식이 필요하다
Persistence Conxtet (영속성 컨텍스트)
공식문서의 정의를 참조해보자
A persistence context is a set of entity instances in which for any persistent entity identity there is a unique entity instance. Within the persistence context, the entity instances and their lifecycle are managed. The
EntityManager
API is used to create and remove persistent entity instances, to find entities by their primary key, and to query over entities.
어렵게 정의되어 있지만 간단하게 요약하자면 영속성 컨텍스트가 영속성 컨텍스트안에 있는 엔티티들의 변화를 추적하고 관리한다는 이야기다.
엔티티 객체의 상태
상태 | 설명 |
Transient | 엔티티 객체가 데이터베이스에 아직 저장되기 전의 상태 |
Persistent | 엔티티 객체가 데이터베이스에 저장된 상태 |
Detached | Persistent 상태였던 엔티티 객체가 더이상 영속성 컨텍스트에 속해있지 않는 상태 |
JPA의 동작들
동작 | 설명 | 특징 |
Save | 하이버네이트 구현체에만 있는 기능 Persist 와 같은 기능. | Persist 는 생성된 ID 를 돌려주지 않으나 Save 는 돌려준다 |
Persist | 엔티티를 영속성 컨텍스트에 포함시킨다 | 1. 엔티티가 Transient 상태라면 엔티티는 Persistent 상태가 된고 관련 동작들을 전파한다. (PERSIST, ALL로 설정된 경우) 2. 엔티티가 이미 Persistent 상태라면 엔티티에 직접적인 영향은 없다. 그러나 관련 동작들은 여전히 자식으로 전파된다 3. 엔티티가 Detached 상태라면 에러를 발생시킨다 |
Merge | Persistent 상태의 엔티티 객체를 Deatched 상태의 객체의 값들로 업데이트한다 | |
Update | 하이버네이트에만 존재하는 동작으로 Merge 와 같은 동작을 수행한다 | |
SaveOrUpdate | 하이버네이트에만 존재하는 동작으로 |
Cascade 종류
JPA 표준에 사용하면 아래와 같이 6가지 Cascade Type 있다
종류 | 특징 |
ALL | 아래에 기술된 모든 동장들을 자식 엔티티에게 전파한다 |
PERSIST | JPA의 Persist 동작 (save, persist )을 부모 엔티티에서 자식 엔티티에게 전파된다 |
MERGE | 부모 엔티티가 업데이트 될때 자식 엔티티들도 업데이트 된다 |
REMOVE | 자식 엔티티들을 부모 엔티티 삭제시 동시에 삭제한다 |
REFRESH | 데이터베이스로부터 데이터르 다시 읽어 들이는 refresh 동작을 부모에서 자식 엔티티로 전파 |
DETACH | Detach 를 부모에서 자식 엔티티로 전파한다 |
하이버네이트에만 존재하는 CaseCade Type
종류 | 특징 |
REPLICATE | Replicate 를 사용할떄 자식엔티티에게도 같은 동작을 전파한다. **자동생성되는 ID 사용하지 않고 엔티티를 복제할 필요가 있을때 사용하면 좋다. |
SAVE_UPDATE | 하이버네이트 구현체의 save, update, saveOrUpdate 동작을 수행시에 자식 엔티티에게 같은 동작을전파한다 |
LOCK | 이미 Detached 된 부모 엔티티 객체를 다시 영속성 객체에 추가시에 자식엔티티도 같이 추가된다 |
참조:
1. https://docs.jboss.org/hibernate/orm/5.6/userguide/html_single/Hibernate_User_Guide.html
'Java > JPA' 카테고리의 다른 글
JPA & Hibernate Cache (0) | 2022.01.19 |
---|