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

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

아리마님의 프로필 이미지
아리마

작성한 질문수

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

임베디드 타입 문의드립니다.

작성

·

183

0

영한님 안녕하세요.

요 몇일동안 열공모드로 달리고 있다보니 질문을 자주 남기게 되네요. (너무 귀찮게 해드려 죄송합니다..)

강의에서 임베디드 타입을 설명해주셨는데 실무에서는 혹시 임베디드 타입만 별도 패키지로 모아놓고 여러 엔티티에서 공통으로 활용을 하는 게 일반적인지 궁금합니다. 아니면 의존성이 어느 정도 있다고 판단하고 엔티티별로 나눠서 사용하는 지 알고 싶네요..

공통으로 쓰는 것도 있을 것 같고, 결합도가 강한 건 따로 빼기도 할 거 같은데 주로 어떻게 사용을 하고 계신가요?

답변 2

1

아리마님의 프로필 이미지
아리마
질문자

네, 잘 이해됐습니다. 오늘도 귀한 의견 감사드립니다.

1

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

안녕하세요. 아리마님^^ 좋은 질문입니다.

임베디드 타입  Value Object여서, 충분히 공용으로 사용 가능한 것들을 주로 뽑게 됩니다. 예를 들어서 x,y를 합친 Point라던가, 기간이라던가 이런 부분들요. 쉽게 이야기해서 비즈니스에 잘 흔들리지 않는 조각들을 주로 뽑게 됩니다. (물론 비즈니스 의존적인 Value Object도 충분히 만들어 질 수 있습니다.)

이것도 결국 프로젝트 규모에서 차이가 납니다. 프로젝트가 작다면 공용으로 모으는게 효율적인데, 프로젝트 규모 크고 한 프로젝트 안에 큰 모듈이 여러가지 있다면, 우선 그 모듈 안에서 사용하는 것이 좋습니다.

예를 들어서 주문, 회원 이 둘을 다 가지고 있는 프로젝트이고, 개념상 소스코드는 한곳에서 관리되지만, 패키지를 크게 나누었다면, Value Object도 공용으로 가지기 보다는 모듈을 벗어나지 않고 사용하는게 좋겠지요.

왜냐하면 생일(예를 들어서) 같은 Value Object는 비즈니스 의존적이지 않는다 해도, 회원 모듈안에서만 사용될 확율이 높기 때문입니다. 따라서 공용으로 가져가면 응집성이 떨어집니다. 가격 같은 Value Object는 주문에서만 주로 사용하겠지요.

반면에 주소라는 Value Object는 회원, 주문 모두에서 사용될 수 있는데, 이런 것은 공용으로 가는게 좋습니다.

감사합니다~

아리마님의 프로필 이미지
아리마

작성한 질문수

질문하기