작성
·
277
3
안녕하세요! 강의 잘 듣고 있습니다~
주문 취소와 주문 가격 조회 비즈니스 메서드를 엔티티 내부에서 선언하신 이유가 궁금합니다!
오더와 달리 멤버의 경우 엔티티에 비즈니스 로직을 작성하지 않은 건 리포지토리에서 사용한 save, find 외에 별다른 로직이 없기 때문인가요?
서비스가 아닌 엔티티에 비즈니스 로직을 위임하는 기준이 궁금합니다!
답변 1
3
안녕하세요. 역삼님
객체지향 디자인 방법중에 GRASP라는 것이 있는데요.
https://en.wikipedia.org/wiki/GRASP_(object-oriented_design)
여기에 보면 information expert라는 것이 있습니다.
쉽게 이야기해서 정보를 가장 잘 알고 있는 곳에 로직(메서드)가 있어야 한다는 것이지요.
여기서 Order는 해당 필드 정보를 가장 잘 알기 때문에 Order가 스스로 해결할 수 있는 부분은 해결하도록 설계되어 있습니다.
반면에 회원의 경우 회원 엔티티가 필드 정보를 가지고 스스로 처리할 비즈니스 로직이 거의 없습니다.
도움이 되셨길 바래요.
저도 이 부분에 대해서 의문을 가졌었는데 위 답변을 보고 해결했습니다! 감사합니다!!
위 의문점을 해결해보면서 객체지향 디자인 패턴에 대해서 더 깊이 있게 공부하고 싶은데, 혹시 추천해주실만한 서적이나 공부 방법이 있으신지 질문 드립니다!