Transaction script/Domain model 패턴에 대한 질문입니다.
2032
작성한 질문수 18
안녕하세요.
항상 좋은 강의 즐겁게 시청하고 있습니다!
강의를 따라가다보니 서비스 레이어가 아닌 엔티티에 비즈니스 로직을 넣어두는 도메인 모델 패턴을 사용하고 계시더라구요.
설명주셨던 것 처럼 코드의 응집도를 높여 중복을 방지하고 재사용성을 높이는 부분에 장점이 크다는 건 잘 알고 있습니다.
저는 현재 실무에서 서비스에 모든 비즈니스 로직을 넣어두는 트랜잭션 스크립트 패턴을 사용하고 있는데요.
도메인별로 서비스를 나눠두고, 해당 서비스에 비즈니스 로직들을 넣어두는 형태로 구현하고 있습니다.
현재 강의에서는 엔티티에 넣어놓은 비즈니스 로직을 서비스에서 단순히 호출만 하는 형태로 사용하고 있는데
서비스 레이어에 넣어둔 비즈니스 로직을 호출하는 형태로 구현해도 어떻게 보면 같은 방식이 아닐까 생각이 들어요. (강의에 나와있는 Order엔티티의 cancel(), createOrder() 등을 엔티티가 아닌 OrderService에 넣어두고 타 서비스에서 필요 시 호출하는 형태)
이렇게 구현을 해도 엔티티에 넣어두는 방식과 동일하게 응집도를 높여 중복을 방지하고 재사용성을 높일 수 있다고 생각합니다.
다만, 아래와 같은 이유들 때문에 도메인 모델 패턴을 선택하시지 않았나 생각합니다.
1. 도메인 모델 패턴이 좀 더 객체지향적임
2. DDD의 일부 개념을 차용하였기 때문
저는 현재 파이썬으로 개발을 하고있는데 파이썬 진영에서는 흔치않는 Layered architecture를 채택해서 진행하다보니 많은 혼란이 오는 것 같습니다.
내용이 조금 더 길어졌는데 질문을 요약하자면,
1. 도메인 모델 패턴을 사용하신 이유가 위에서 말씀드린 1, 2번때문이 맞을까요?
2. 서비스 레이어에 로직을 몰아넣고 필요할 때 쓰는 방식도 응집도를 높여 중복을 방지하고 재사용성을 높일 수 있다고 보는데 어떻게 생각하시나요?
이 부분에 대해 영한님의 생각을 듣고 싶습니다 :)
답변 1
sdk 설정 오류
0
43
2
오탈자 - @Transactional
0
50
1
src/test/resources 테스트 경로 문제
0
49
1
상품 등록후 H2 db 출력 순서 바꿀 수 있나요?
0
62
1
MemberRepositoryTest 실행오류
0
73
1
boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)
1
180
2
강의 마지막 QueryDSL 사용 부분 질문있습니다
1
135
2
클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.
0
50
1
도메인 모델 패턴 vs 트랜잭션 스크립트 패턴
0
71
1
기본 생성자
0
58
1
h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.
0
100
1
멤버서비스테스트 부분에서 막힙니다.
0
163
4
실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?
0
115
1
초반에 h2 다운로드 과정 꼭 필요한가요?
0
117
2
자신 필드에도 get으로 접근하는 이유가 있을까요?
0
108
1
24분 27초 연관관계 편의 메서드 위치
0
111
1
단건 주문만 가능하게 한건 의도한 부분이신가요?
0
106
2
빌드 툴, Gradle
0
57
1
h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다
0
73
2
Repository에서 EntityManager 주입 방식 차이
0
87
1
롬복과 사용자 정의 setter 메서드
0
70
1
주문 목록 조회 fetch join 질문드립니다
0
79
1
dirty checking 질문드립니다.
0
78
1
동시성 관련 질문입니다
0
70
1





