인프런 커뮤니티 질문&답변

이지훈님의 프로필 이미지
이지훈

작성한 질문수

실전! 스프링 데이터 JPA

사용자 정의 리포지토리 구현

리포지토리 분리

작성

·

301

1

리포지토리를 분리하신다고 하셨는데

1. 정말 간단한 쿼리는 스프링 데이터 JPA 리포지토리에서 구현, 쿼리메서드 기능들을 이용하고

조금 복잡하고, 강의에서 설명해주신 다양한 이유에 해당하면 사용자 정의 리포지토리를 구현해서 사용하고

더 복잡한 동적쿼리들은 따로 클래스를 만들어서
총 3개의 리포지토리를 운영하게 되는건가요?

2. 서비스와 리포지토리는 1:1로 매핑하는게 좋다고 들었는데 그럼 3개의 서비스클래스도 따로 만드나요?

3. 핵심 비즈니스 로직과 단순 화면 관련 로직도 구분은 서비스계층에서 이루어지나요? 그럼 하나의 서비스에서 두개의 리포지토리를 접근해도 괜찮나요??

아직 아키텍처를 고민할만한 실력은 아니지만
궁금점이 해결되지 않아 질문남깁니다..

답변 2

2

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 지훈님 좋은 질문입니다.

1. 네 맞습니다. 그런데 간단한 리포지토리는 스프링 데이터 JPA만으로 끝나겠지요? 대부분의 경우 사용자 정의 리포지토리 정도에서 정리됩니다.

2. 서비와 리포지토리는 1:1로 매핑하는 것은 연통배관이라고 하는 안티패턴입니다. 다양한 서비스가 서로 다양한 리포지토리를 사용하도록 설계해서 리포지토리의 재사용성을 높이는 것이 일반적으로 좋은 설계입니다.

3. 네 괜찮습니다^^ 심지어 서비스 자체를 특별한 조회용 서비스가 있다면 분리해도 됩니다.

도움이 되셨길 바래요^^

1

이지훈님의 프로필 이미지
이지훈
질문자

안티패턴이였군요..!

항상 감사합니다~

이지훈님의 프로필 이미지
이지훈

작성한 질문수

질문하기