ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • 주문과 할인 도메인 설계
    FrameWork/Spring&Spring-boot 2021. 12. 29. 15:53

    주문과 할인 정책

    • 회원은 상품을 주문할 수 있다.
    • 회원 등급에 따라 할인 정책을 적용할 수 있다.
    • 할인 정책은 모든 VIP는 1000원을 할인해주는 고정 금액 할인을 적용해 달라(나중에 변경 될 수 있다.)
    • 할인 정책은 변경 가능성이 높다. 회사의 기본 정책을 아직 정하지 못헸고, 오픈 직전까지 고민을 미루고 싶다. 최악의 경우 할인을 적용하지 않을 수 도 있다.(미확정)

    주문 도메인 협력,역할 책임

    1. 주문 생성 : 클라이언트는 주문 서비스에 주문 생성을 요청한다.
    2. 회원 조회 : 할인을 위해서는 회원 등급이 필요하다. 그래서 주문 서비스는 회원 저장소에서 회원을 조회한다.
    3. 할인 적용 : 주문 서비스는 회원 등급에 따른 할인 여부를 할인 정책에 위임한다.
    4. 주문 결과 반환 : 주문 서비스는 할인 결과를 포함한 주문 결과를 반환한다. 

    참고 :  실제로는 주문 데이터를 DB에 저장하겠지만, 예제가 너무 복잡해 질 수 있어서 생략하고, 단순히 주문 결과를    반환한다.  

     

     

    주문 도메인 전체

    *역할구현을 분리 해서 자유롭게 구현 객체를 조립할 수 있게 설계했다. 덕분에 회원 저장소는 물론이고, 할인 정책도 유연하게 변경할 수 있다.

     

    주문 도메인 클래스 다이어그램

    주문 도메인 객체 다이어그램1

     

    -객체 다이어그램은 클래스 다이어그램과 다르게, 실제 new로 생성, 어플리케이션을 띄어서

    ->동적으로 객체들의 연관 관계가 맺어 진다.

    회원을 메모리에서 조회하고, 정액 할인 정책(고정 금액)을 지원해도 주문 서비스를 변경하지 않아도 된다.

    역할들의 협력 관계를 그대로 재사용 할 수 있다.

     

    주문 도메인 객체 다이어그램2

    회원을 메모리가 아닌 실제 DB에서 조회하고, 정률 할인 정책(주문 금액에 따라 % 할인)을 지원해도 주문 서비스를 변경하지 않아도 된다.

     

    [출처 : 김영한. 스프링 핵심 원리-기본편. 인프런]

     

    'FrameWork > Spring&Spring-boot' 카테고리의 다른 글

    Junit-Assert 메소드  (0) 2021.12.29
    주문과 할인 도메인 개발  (0) 2021.12.29
    회원 도메인 실행과 테스트  (0) 2021.12.29
    회원 도메인 개발  (0) 2021.12.29
    회원 도메인 설계  (0) 2021.12.29

    댓글

Designed by Tistory.