inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

@OneToOne, @OneToMany만 가능한 이유

102

오리쉐리

작성한 질문수 108

0

안녕하세요.

강의와 강의 자료를 보는 도중,

강의 자료에 있는 고아객체 - 주의 부분에서, @OneToOne, @OneToMany만 가능한 이유에 대해서는 특별히 설명을 안해주신거 같아서요..

혹시 @OneToOne, @OneToMany만 가능한 이유가 무엇인지 알 수 있을까요?

감사합니다.

java jpa

답변 2

0

김영한

안녕하세요. 오리쉐리님

JPA에서 고아 객체(Orphan Removal) 기능이 @OneToOne과 @OneToMany 관계에서만 사용 가능한 이유는 다음과 같습니다:

  1. 소유권(Ownership)의 명확성:

    • @OneToOne과 @OneToMany 관계에서는 '소유하는 측'과 '소유되는 측'이 명확합니다. 부모 엔티티가 자식 엔티티를 명확하게 소유합니다.

    • 따라서 부모 엔티티에서 자식 엔티티의 참조를 제거했을 때, 해당 자식이 '고아'가 되었다고 판단하기 용이합니다.

  2. @ManyToMany에서의 문제점:

    • 다대다 관계에서는 양쪽 엔티티 모두 컬렉션으로 서로를 참조합니다.

    • 한 쪽에서 참조를 제거했다고 해서 그 객체가 진정한 '고아'라고 할 수 없습니다. 다른 엔티티에서 여전히 참조할 수 있기 때문입니다.

    • 이런 상황에서 고아 객체 제거를 허용하면 예상치 못한 데이터 손실이 발생할 수 있습니다.

  3. @ManyToOne에서의 문제점:

    • 다대일 관계에서는 '다(Many)' 쪽의 여러 엔티티가 '일(One)' 쪽의 하나의 엔티티를 참조합니다.

    • 한 엔티티가 참조를 끊었다고 해서 참조 대상이 고아가 되는 것이 아닙니다. 다른 엔티티들이 여전히 참조하고 있을 수 있습니다.

고아 객체 제거는 부모-자식 관계가 명확하고, 자식 엔티티의 생명주기가 부모 엔티티에 완전히 종속된 경우에만 안전하게 사용할 수 있으므로 @OneToOne과 @OneToMany에서만 허용됩니다.

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 오리쉐리님.

고아 객체란 부모 객체와의 관계가 끊어졌을 때, 자동으로 삭제되는 엔티티를 의미합니다. 이 기능은 JPA에서 @OneToOne과 @OneToMany 관계에서만 지원됩니다. 그 이유는 이 두 가지 관계가 고아 객체 상태를 명확하게 판단할 수 있는 유일한 방향성 관계를 가지기 때문입니다.

  • @OneToOne: 이 관계는 두 엔티티가 일대일로 연결되며, 한쪽 엔티티가 제거되면 연결된 엔티티가 고아 상태가 되어 함께 삭제될 수 있습니다.

  • @OneToMany: 여러 엔티티가 하나의 부모 엔티티에 종속되는 구조이기 때문에, 부모 엔티티에서 참조가 제거되면 종속된 엔티티에서 고아 상태를 식별하고 삭제할 수 있습니다.

다대다(@ManyToMany)나 다대일(@ManyToOne) 관계에서는 고아 객체 기능이 지원되지 않는 것은 구조적으로 고아 객체 개념이 명확하게 정의되기 어렵기 때문입니다.

추가적으로 필요하신 정보가 있다면, JPA 연관관계와 관련된 내용에 대해 이미 많은 질문이 올라와 있으니, Inflearn 내 Q&A 게시판에서도 다른 학습자의 질문과 답변을 참고하셔도 좋을 것 같습니다.

관련 질문: item에서는 @OneToMany를 안적는 이유가 있나요?

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

32

2

inheritance startegy 선택시 고려사항

0

24

1

Entity 동등성 비교

0

23

1

실무 조언 관련 질문입니다.

0

48

1

H2데이터베이스 파일 생성

0

58

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

55

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

57

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

61

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

96

2

UnsupportedOperationException 발생

0

86

3

H2 Database 연결이 안됩니다.

0

97

2

연관관계 매핑 질문드립니다.

0

87

2

h2데이터베이스 실행오류

0

110

2

persistence.xml

0

112

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

83

1

영속성 컨텍스트

0

69

1

JPA 프록시

0

98

1

Native Query와 MyBatis

0

71

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

90

1

임베디드 타입 예시 코드 관련 질문

0

121

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

96

3

인텔리제이 패키지 커서 단축키 질문

0

109

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

149

1