inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

서비스 계층 설계에 대해 질문이 있습니다

251

hsg0208

작성한 질문수 16

0

안녕하세요 강의를 잘 듣고 현재 프로젝트를 진행하고있는 학생입니다.

프로젝트를 시작하고 설계를 하는 과정중에서 계층을 설계하는 단계에서 어려움을 느껴 이렇게 질문을 남기게 되었습니다.

저희가 서비스 계층을 설계하려 하는데 사용자의 행위(저장, 검색, 수정)에 따라 다른 클래스로 구분을 해야하는지, 단순히 프로그램에서 구현되는 페이지별로 클래스를 구분을 하는것이 좋은지, 혹은 다른 설계 방법이 있는지에 대하여 알려주시면 감사하겠습니다. 

java spring 웹앱 JPA spring-boot

답변 1

1

김영한

안녕하세요. hsg0208님

다음을 참고해주세요.

https://www.inflearn.com/questions/16046

감사합니다.

0

hsg0208

먼저 달아주신 링크 내용을 보고 패키지구조 설계에대한 정답은 없다는것을 잘 알게 되었습니다. 

하지만 저희가 아무래도 처음 이런 계층구조로 설계를 하다보니 특히 서비스 계층 설계에서 어려움이 생겼습니다.

제 생각으로는 이런 서비스들을 쇼핑몰에서 보듯이 리소스에 대한 서비스로 계층을 만드는 것이 좋다고 생각 했는데 (예를 들면 주문, 회원, 아이템 과 같이 명확하게 구조화 될 수있는? 물론 나머지 배송이나 아이템 하위에 있는 항목들은 위 3개에 종속적이니 제외하는 것이라 생각 합니다!) 이런 리소스 들은 해당 정보를 한페이지에서 관리 하다 보니 토의를 통해서 이 서비스 계층이란 것이 페이지 별로 만드는 것이 적합한가에 대한 고민이 나왔습니다. 저희가 진행하고 있는 프로잭트는 페이지 별로 각각의 리소스에 대해 점진적으로 column 정보를 넣어주는 쪽이다 보니 리소스 별로 추가1 추가2 추가3 ... 을 만들기에는 코드가 너무 더러워 지는 것 같아서 고민이였습니다.

간단하게 말해

저희가 만들고 있는 프로잭트를 간단히 보면 페이지 별로 리소스에 대한 추가 수정 삭제가 있습니다

이 추가 수정 삭제 기능들을 각각 서비스로 만들어서 개발을 해야하는지 (추가service, 삭제service, 수정service) 혹은 페이지별로 서비스를 나눠서(PageAService, PageBService, PageCService) 개발 혹은 리소스 별로 서비스 계층을 구현하는것이 좋은지에 대한 조언을 얻고자 합니다.

 

0

김영한

안녕하세요. hsg0208님

서비스 계층을 화면별로 나누게 되면, 결과적으로 화면을 수정할 때 서비스도 수정되어야 합니다.

따라서 상황에 따라서 다르지만 일반적으로 서비스는 가급적 화면에 종속적이지 않게 설계하는 것이 좋습니다.

감사합니다.

OrderServiceTest 상문주문 테스트 시 update 쿼리 문의

0

30

1

sdk 설정 오류

0

71

2

오탈자 - @Transactional

0

68

1

src/test/resources 테스트 경로 문제

0

68

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

71

1

MemberRepositoryTest 실행오류

0

91

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

198

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

154

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

58

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

82

1

기본 생성자

0

67

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

107

1

멤버서비스테스트 부분에서 막힙니다.

0

176

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

125

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

129

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

122

1

24분 27초 연관관계 편의 메서드 위치

0

118

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

115

2

빌드 툴, Gradle

0

65

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

82

2

Repository에서 EntityManager 주입 방식 차이

0

98

1

롬복과 사용자 정의 setter 메서드

0

78

1

주문 목록 조회 fetch join 질문드립니다

0

91

1

dirty checking 질문드립니다.

0

88

1