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

정원be님의 프로필 이미지
정원be

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

주문, 주문상품 엔티티 개발

비즈니스 로직을 엔티티에 위임하는 기준이 궁금합니다!

작성

·

277

3

안녕하세요! 강의 잘 듣고 있습니다~

주문 취소와 주문 가격 조회 비즈니스 메서드를 엔티티 내부에서 선언하신 이유가 궁금합니다!

오더와 달리 멤버의 경우 엔티티에 비즈니스 로직을 작성하지 않은 건 리포지토리에서 사용한 save, find 외에 별다른 로직이 없기 때문인가요?

서비스가 아닌 엔티티에 비즈니스 로직을 위임하는 기준이 궁금합니다!

답변 1

3

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

안녕하세요. 역삼님

객체지향 디자인 방법중에 GRASP라는 것이 있는데요.

https://en.wikipedia.org/wiki/GRASP_(object-oriented_design)

여기에 보면 information expert라는 것이 있습니다.

쉽게 이야기해서 정보를 가장 잘 알고 있는 곳에 로직(메서드)가 있어야 한다는 것이지요.

여기서 Order는 해당 필드 정보를 가장 잘 알기 때문에 Order가 스스로 해결할 수 있는 부분은 해결하도록 설계되어 있습니다.

반면에 회원의 경우 회원 엔티티가 필드 정보를 가지고 스스로 처리할 비즈니스 로직이 거의 없습니다.

도움이 되셨길 바래요.

저도 이 부분에 대해서 의문을 가졌었는데 위 답변을 보고 해결했습니다! 감사합니다!!
위 의문점을 해결해보면서 객체지향 디자인 패턴에 대해서 더 깊이 있게 공부하고 싶은데, 혹시 추천해주실만한 서적이나 공부 방법이 있으신지 질문 드립니다!

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

네 현준님 이미 시중에 좋은 객체지향 관련 책과 디자인 패턴 책들이 많이 있어서 보시고 본인에게 맞는 책을 보시면 좋을 것 같아요^^

정원be님의 프로필 이미지
정원be

작성한 질문수

질문하기