@Repository@RequiredArgsConstructorpublic class HubQueryRepository implements CustomHubRepository { private final JPAQueryFactory queryFactory; @Override public Page findDynamicQuery(HubSearchCriteria criteria, Pageable pageable) { JPAQuery query = queryFactory .selectFrom(hub) .where( eqId(criteria.getId()), eqName(criteria.getName()), eqAddress(criteria.getAddress()), eqLatitu..
팀 구성팀명5잉메리호팀원김기훈이지언이예본이하은전은배 S.AAPI 명세서https://www.notion.so/teamsparta/API-1b32dc3ef51480ef8855e1b7bb840b1a테이블 명세서https://www.notion.so/teamsparta/1b32dc3ef514802d84a1dba22aa3c429ERD 명세서https://www.erdcloud.com/d/GapKxaBr7GMZghHXB projectDraw ERD with your team members. All states are shared in real time. And it's FREE. Database modeling tool.www.erdcloud.com인프라 설계서https://www.notion.so/teamspa..
여러 애그리거트가 필요한 기능도메인 영역의 코드를 작성하다 보면, 한 애그리거트로 기능을 구현할 수 없는 경우가 있습니다. 대표적으로, 결제 금액 계산 로직이 있는데 다음과 같은 내용이 필요합니다.상품 애그리거트주문 애그리거트할인 쿠폰 애그리거트회원 애그리거트이때 생각해볼 수 있는 방법은 '주문 애그리거트'가 필요한 데이터를 모두 가지도록 한 뒤 할인 금액 계산 책임을 주문 애그리거트에 할당하는 방법입니다. 만약 이때, 특별 감사 세일을 적용해 한 달간 2% 추가 할인을 적용하면 어떻게 될까요? 이 할인 정책은 주문 애그리거트의 구성요소와 관련이 없음에도 주문 애그리거트의 코드를 수정해야 합니다. 이 경우 다음과 같은 문제점이 발생합니다.자신의 책임 범위를 넘어서는 기능을 구현하게 된다.외부에 대한 의존..
표현 영역의 책임은 크게 다음과 같습니다.사용자가 시스템을 사용할 수 있는 흐름(화면)을 제공하고 제어한다.사용자의 요청을 알맞은 응용 서비스에 전달하고 결과를 사용자에게 제공한다.사용자의 세션을 관리한다.값 검증값 검증은 표현 영역과 응용 서비스 두 곳에서 모두 수행할 수 있습니다. 원칙적으로는 모든 값에 대한 검증은 응용 서비스에서 처리합니다.표현 영역과 응용 서비스는 값 검사를 다음과 같이 나누어 수행할 수 있습니다.표현 영역 : 필수 값, 값의 형식, 범위 등을 검증응용 서비스 : 데이터의 존재 유무와 같은 논리적 오류를 검증하지만, 응용 서비스에서 필요한 값 검증과 논리적 값 검증을 모두 처리하면 작성할 코드가 늘어나는 불편함이 있지만, 응용 서비스의 완성도가 높아진다는 장점 또한 존재합니다. ..
앞선 포스팅에서는 도메인 영역과 관련해 살펴 보았습니다. 이 도메인이 제 기능을 하기 위해서는 사용자와 도메인을 연결해 주는 매개체가 필요하며 응용 영역과 표현 영역이 이 매개체 역할을 합니다. 이번 포스팅에서는 응용 영역에 대해 알아보겠습니다.응용 서비스응용 서비스는 사용자(클라이언트)가 요청한 기능을 실행합니다.주요 역할도메인 객체를 사용해 사용자의 역할을 처리트랜잭션 처리응용 서비스는 주로 도메인 객체 간의 흐름을 제어하기에 아래와 같이 단순한 형태를 가집니다.일반적인 기능public Result doSomeFunc(SomeReq req) { // 1. 리포지터리에서 애그리거트를 구한다. SomeAgg agg = someAggRepository.findById(req.getId()); checkN..
이번 포스팅에서는 자바의 ORM 표준인 JPA를 이용해 리포지터리와 애그리거트를 구현하는 방법에 대해 살펴보겠습니다. 앞선 포스팅에서 설명한 것처럼 리포지터리 인터페이스는 애그리거트와 같은 도메인 영역에 속하고, 이를 구현한 클래스는 인프라스트럭처 영역에 속합니다.가능하면 위와 같이 리포지터리 구현 클래스를 인프라스트럭처 영역에 위치시켜 인프라스트럭처에 대한 의존을 낮추는 것이 중요합니다.리포지터리 인터페이스는 애그리거트 루트를 기준으로 작성합니다.애그리거트를 수정한 결과를 저장소에 반영하는 메서드는 필요없습니다.JPA를 사용하면 트랜잭션 범위에서 변경한 데이터를 자동으로 DB에 반영합니다.JPA는 변경된 객체의 데이터를 DB에 반영하기 위해 UPDATE 쿼리를 실행합니다.매핑 구현애그리거트와 JPA 매..
애그리거트란?하나의 시스템을 개발할 때, 상위 수준 개념을 이용해서 전체 모델을 정리하면 전반적인 관계를 이해하는 데 도움이 됩니다.쇼핑몰을 예시로 들면, 아래와 같이 표현할 수 있습니다.이를 개별 객체 단위로 다시 그려보면 아래와 같습니다.여기서 도메인 객체 모델이 복잡해지면 개별 구성요소 위주로 모델을 이해하게 되고, 전반적인 구조나 큰 수준에서 도메인 간의 관계를 파악하기 어려워지게 됩니다. 결국, 복잡한 도메인을 이해하고 관리하기 쉬운 단위로 만들려면 상위 수준에서 모델을 조망할 수 있는 방법이 필요한데, 이 방법이 애그리거트 입니다. 애그리거트를 한 마디로 표현한다면,관련된 객체들의 집합을 하나의 단위로 취급하는 패턴입니다.즉, 도메인 모델에서 밀접하게 관련된 객체들의 집합을 의미합니다. 이는 ..
계층 구조 아키텍처네 영역을 구성할 때 많이 사용하는 아키텍처는 아래와 같은 계층 구조입니다.계층 구조는 특성상 상위 계층에서 하위 계층으로의 의존만 존재하고 하위 계층은 상위 계층에 의존하지 않습니다. 하지만, 편리함을 위해 아래와 같이 응용 계층에서 인프라스트럭처 계층에 직접 의존하는 계층 구조를 가지기도 합니다.응용, 도메인 영역이 DB나 외부 시스템 연동을 위해 인프라스트럭처의 기능을 사용하므로, 위의 구조는 직관적으로 이해하기 쉽습니다. 하지만, 이 경우표현, 응용, 도메인 계층이 상세한 구현 기술을 다루는 인프라스트럭처 계층에 종속되게 됩니다. 도메인의 "가격 계산 규칙"을 예시로 들어보겠습니다.우선, Dr∞ls라는 룰 엔진을 통해 계산 로직을 수행하는 인프라스트럭처 영역의 코드입니다.p..
Redis는 기본적으로 Key-Value 데이터베이스 입니다. 따라서, 대부분의 명령이 Key를 바탕으로 동작하고, Value로 사용하고자 하는 자료형에 따라 다른 명령어를 사용하게 됩니다. StringString은가장 기본적인 자료형Java의 Map처럼 동작저장할 수 있는 최대 크기는 512MBSET, GETSET user:email alex@example.comGET user:emailSET : key에 value 문자열 데이터를 저장합니다.GET : key에 저장된 문자열을 반환합니다.INCR, DECR만약, 저장된 데이터가 정수 데이터라면 증가, 감소가 가능합니다.SET user:count 1INCR user:countDECR user:countINCRkey : key에 저장..
도메인이란?도메인이란해결하고자 하는 문제의 영역을 말합니다. 한 도메인은 다시 하위 도메인으로 나눌 수 있습니다.예를 들어, "온라인 서점"이라는 도메인은 다음과 같은 하위 도메인으로 나눌 수 있습니다.회원주문결제배송카탈로그리뷰정산혜택도메인 모델도메인 모델이란특정 도메인을 개념적으로 표현한 것입니다. 주문 도메인을 예시로 객체 모델로 구성하면 다음과 같이 나타낼 수 있습니다.도메인을 이해하려면 도메인이 제공하는 기능과 도메인의 주요 데이터 구성을 파악해야 합니다. 이런 면에서 기능과 데이터를 함께 보여주는 객체 모델은 도메인을 모델링하기에 매우 적합합니다.물론, 객체가 아닌 상태 다이어그램, 수학 공식 등을 통해 모델링하는 방법도 존재합니다. 즉, 도메인을 이해하는 데 도움이 된다면 표현 방식이 무엇인지..
내 블로그 - 관리자 홈 전환 |
Q
Q
|
---|---|
새 글 쓰기 |
W
W
|
글 수정 (권한 있는 경우) |
E
E
|
---|---|
댓글 영역으로 이동 |
C
C
|
이 페이지의 URL 복사 |
S
S
|
---|---|
맨 위로 이동 |
T
T
|
티스토리 홈 이동 |
H
H
|
단축키 안내 |
Shift + /
⇧ + /
|
* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.