작성
·
17
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
여기에 질문 내용을 남겨주세요.
안녕하세요. 잘 보고 있습니다.
컨트롤러에서 Repository에 바로 의존성이 있는 방식으로 사용하는 예제를 알려주셨는데 간단한 예시를 들어주시느라 사용하신 패턴이신가요?
아니면 어차피 페이징 기능은 레포지토리 단의 간단한 메서드로 충분히 수행되므로 서비스 레이어를 통한 매핑이 불필요해서 그러신건가요??
답변 2
0
안녕하세요. 김해찬님, 공식 서포터즈 OMG입니다.
단순 엔티티 조회성인 경우, 실용적인 관점에서 Controller -> Repository를 직접 참조하여 사용하시기도 합니다😀
아래 영한님 답변을 참고해주세요 ^^
https://www.inflearn.com/community/questions/15024
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다. 김해찬님.
스프링 애플리케이션에서 Controller와 Repository 간의 직접 연결에 대해 궁금하셨는데요, 일반적으로 컨트롤러는 비즈니스 로직 처리를 위해 서비스 계층을 사용하고, 서비스 계층을 통해 Repository와 상호 작용합니다. 이는 코드의 재사용성과 응집도를 높이고, 비즈니스 로직을 잘 분리하기 위해 권장되는 방식입니다.
하지만, 간단한 데이터 조회의 경우, Service 계층을 굳이 사용하지 않고 Controller에서 직접 Repository를 참조하여 처리하기도 합니다. 이는 주로 불필요한 코드 복잡성을 줄이기 위한 실용적인 접근법으로, 이러한 경우 Service 계층에서 추가적인 로직 처리가 필요하지 않은 상황에 사용하기도 합니다.
다음은 유사한 질문에 대한 답변 링크입니다. 자세한 설명을 통해 더 많은 이해를 도울 수 있을 것입니다:
Controller에서 직접 Repository에 접근하는 이유
주문 목록 검색 컨트롤러에서 @ModelAttribute가 적용된 orderSearch 질문
이러한 접근은 개발팀의 코드 스타일 및 프로젝트 요구 사항에 따라 달라질 수 있으니 참고하시기 바랍니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.