비즈니스 로직을 엔티티에 위임하는 기준이 궁금합니다!
365
작성한 질문수 1
안녕하세요! 강의 잘 듣고 있습니다~
주문 취소와 주문 가격 조회 비즈니스 메서드를 엔티티 내부에서 선언하신 이유가 궁금합니다!
오더와 달리 멤버의 경우 엔티티에 비즈니스 로직을 작성하지 않은 건 리포지토리에서 사용한 save, find 외에 별다른 로직이 없기 때문인가요?
서비스가 아닌 엔티티에 비즈니스 로직을 위임하는 기준이 궁금합니다!
답변 1
3
안녕하세요. 역삼님
객체지향 디자인 방법중에 GRASP라는 것이 있는데요.
https://en.wikipedia.org/wiki/GRASP_(object-oriented_design)
여기에 보면 information expert라는 것이 있습니다.
쉽게 이야기해서 정보를 가장 잘 알고 있는 곳에 로직(메서드)가 있어야 한다는 것이지요.
여기서 Order는 해당 필드 정보를 가장 잘 알기 때문에 Order가 스스로 해결할 수 있는 부분은 해결하도록 설계되어 있습니다.
반면에 회원의 경우 회원 엔티티가 필드 정보를 가지고 스스로 처리할 비즈니스 로직이 거의 없습니다.
도움이 되셨길 바래요.
0
저도 이 부분에 대해서 의문을 가졌었는데 위 답변을 보고 해결했습니다! 감사합니다!!
위 의문점을 해결해보면서 객체지향 디자인 패턴에 대해서 더 깊이 있게 공부하고 싶은데, 혹시 추천해주실만한 서적이나 공부 방법이 있으신지 질문 드립니다!
OrderServiceTest 상문주문 테스트 시 update 쿼리 문의
0
27
1
sdk 설정 오류
0
63
2
오탈자 - @Transactional
0
59
1
src/test/resources 테스트 경로 문제
0
55
1
상품 등록후 H2 db 출력 순서 바꿀 수 있나요?
0
69
1
MemberRepositoryTest 실행오류
0
86
1
boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)
1
190
2
강의 마지막 QueryDSL 사용 부분 질문있습니다
1
150
2
클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.
0
56
1
도메인 모델 패턴 vs 트랜잭션 스크립트 패턴
0
79
1
기본 생성자
0
65
1
h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.
0
106
1
멤버서비스테스트 부분에서 막힙니다.
0
171
4
실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?
0
122
1
초반에 h2 다운로드 과정 꼭 필요한가요?
0
128
2
자신 필드에도 get으로 접근하는 이유가 있을까요?
0
117
1
24분 27초 연관관계 편의 메서드 위치
0
117
1
단건 주문만 가능하게 한건 의도한 부분이신가요?
0
114
2
빌드 툴, Gradle
0
63
1
h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다
0
80
2
Repository에서 EntityManager 주입 방식 차이
0
96
1
롬복과 사용자 정의 setter 메서드
0
77
1
주문 목록 조회 fetch join 질문드립니다
0
89
1
dirty checking 질문드립니다.
0
86
1





