인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

조태준님의 프로필 이미지

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

영속성 전이(CASCADE)와 고아 객체

연관관계 매핑과의 관련

작성

·

69

0

강사님께서 수업을 시작하면서 해당 장은 연관관계를 세팅하는 것과는 관련이 없다고 말씀을 해주셨습니다.

 

연관관게 매핑 시간에 배운 내용에 의하면 Parent 엔티티에 있는 childList 는 읽기 전용이 됩니다.

하지만 cascade 속성에 의해 읽기 전용이 무력화? 되는 듯한 느낌입니다.

 

그래서 정리를 해보자면

"연관관계 주인 반대쪽(mappedBy 를 쓰는 쪽)의 읽기 전용은 cascade 속성에 의해 소용이 없어질 수 있다."

라고 생각하면 될까요?

답변 2

1

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 조태준님

핵심은 cascade와 mappedBy는 서로 전혀 다른 기능을 제공한다는 것입니다.

(서로 관계가 없는 다른 두 기능이라고 생각하시면 됩니다.)

추가로 다음 답변을 참고해주세요.

https://inf.run/yvnW2

감사합니다.

0

조태준님의 프로필 이미지
조태준
질문자

몇가지 테스트를 해보니까 또 읽기 전용은 계속 유지가 되는 거 같은 생각이 드네요

 

연관관계 편의 메서드에서 연관관계 주인 쪽을 수정하는 부분(child.setParent(this))을 주석 치고 테스트를 해보았습니다.

// JpaMain.java
Child child1 = new Child();
Child child2 = new Child();

Parent parent = new Parent();
parent.addChild(child1);
parent.addChild(child2);

em.persist(parent);

tx.commit();

// ================================================

// Parent.java
public void addChild(Child child) {
        childList.add(child);
        // child.setParent(this);
}

 

이렇게 해도 child1child2INSERT가 되더라고요.

대신, PARENT_ID 컬럼에는 null 값이 들어갑니다.

 

질문1) 그렇다면 아래와 같이 정리한 내용이 맞나요?

  • INSERT 가 되는 이유는 cascade 속성 때문이고

  • null 값이 들어간 이유는 읽기 전용이기 때문이다

 

질문2) 만약 읽기 전용이 아닐 때(mappedBy를 안 적었을 때)는, 주인 쪽에 setParent() 를 안 하고 주인 반대쪽에서 childList.add() 만 해도 PARENT_ID 컬럼에 값이 들어가죠?

 

질문3) 질문1의 내용이 맞다면, orphanRemoval=true 는 진짜 읽기 전용 속성을 무시하게 해준다고 생각해도 되나요?