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

oniic님의 프로필 이미지
oniic

작성한 질문수

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

고아객체 질문입니다.

작성

·

29

0

안녕하세요. 섹션 9-3 질문입니다.

고아 객체 주의할 점에 특정 엔터가 개인 소유할 때 사용하는 것인데, 개인 소유가 아니고 다른 엔티티가 참조할 때 문제가 있나요? 예를 들어 부모 엔터티를 삭제하면 고아객체인 자식 엔터티도 삭제가 될 텐데 어차피 삭제할 때 자식 엔터티의 id(pk)를 보고 삭제를 할텐데 다른 엔터티가 참조해도 영향이 없지 않나요?

 

감사합니다.

답변 1

1

안녕하세요. oniic님, 공식 서포터즈 y2gcoder입니다.

간단한 예시를 드리자면,

예를 들어 회원과 주문을 1:N의 관계로 생성했다고 가정해보겠습니다. 이 때 회원에 대하여 주문을 고아 객체일 때 지워지는 것으로 설정했다고 가정해보겠습니다.

만약 그렇게 했다면 잘못해서 회원 데이터의 삭제(탈퇴 등으로)로 인해 주문도 같이 지워지면 정산과 통계 모두 영향을 받을 것입니다.

(물론 일반적인 경우 회원이 탈퇴했다고 해서 회원의 데이터를 삭제하지 않습니다)

 

감사합니다.

oniic님의 프로필 이미지
oniic
질문자

감사합니다. 그러면 말씀하신 영향도가 전혀 없는 경우 고아 객체를 여러 개의 엔티티에서 참조하도록 설계해도 상관 없는건가요? (좋은 설계가 아닌 것 같지만 가능은 한가요?)

말씀하신 상황에서 고아 객체를 설정하기 위해 최악의 경우에는 고아 객체 부분을 수정할 때 엮여있는 엔티티를 모두 검토해야 하는 비용과 트레이드 오프를 따지고, 테스트 코드를 정말 잘 작성해놓을 수 있고, 같이 협업하는 분들께도 이 부분을 주지시킬 수 있다고 하면 저는 설정해볼 수 있을 것 같습니다!

거기에 더해 지금 도메인 상황에서는 괜찮더라도 추후에 수정해야 할 때의 비용까지도 고려해야 합니다!

oniic님의 프로필 이미지
oniic

작성한 질문수

질문하기