OrderRepository를 JpaRepository를 사용하여 작성하고 싶습니다.
MemberReposiotry처럼 OrderRepository도 JpaRepository를 사용하여 변경해봤습니다.
근데 여기서 기존의 검색 기능을 담당하던 findAllByString의 메서드를 구현함에 있어서 오류가 발생하여 질문드립니다.
기존과 같이 OrderSearch를 이용하여 작성하고 싶어서 findALlByMemberName으로 OrderSearch의 필드인 MemberName을 가져오고 싶었으나 타입 불일치로 오류가 발생합니다.
기존의 Service와 Controller의 변경 없이 Repository만으로 해결하고 싶은데 어떻게 작성해야 할까요?
findAllByString은 동적쿼리라서 JpaRepsitory의 기능으로 해결하기엔 한계가 있나요?


답변 1
1
안녕하세요, 박재언 님. 공식 서포터즈 y2gcoder 입니다.
현재 Spring Data JPA의 JpaRepository를 상속하는 방식으로 바꾼 Repository에서 findAllByString()도 같이 사용하고 싶으신 것으로 이해했습니다.
결론부터 말씀드리자면 현재 구조로는 사용이 어렵고, 사용자 정의 리포지토리를 구현하는 방식으로 가능할 것 같습니다. 사용자 정의 리포지토리를 이용하면 EntityManager를 사용하는 것 뿐만 아니라 JdbcTemplate, Querydsl 등도 같이 사용할 수 있습니다.
1) findAllByString()를 정의한 인터페이스를 만듭니다.(이름은 원하시는 것으로 해주세요!)
public interface OrderRepositoryCustom {
List<Order> findAllByString(OrderSearch orderSearch);
}2) 해당 인터페이스를 구현한 리포지토리를 만들어주십시오. 여기서는 원본 코드를 그냥 가져오기 위해서 EntityManager를 사용하는 방법을 사용했습니다.
** 여기서 반드시 구현체의 이름은 JpaRepository를 상속한 Repository 인터페이스 + Impl 이나 1)에서 만든 인터페이스 + Impl로 해주시길 바랍니다!
ex) Spring Data JPA 의 JpaRepository를 상속한 리포지토리 인터페이스: OrderRepository, 1)의 인터페이스명: OrderRepositoryCustom
=> 가능한 구현체명: OrderRepositoryImpl , OrderRepositoryCustomImpl
@RequiredArgsConstructor
public class OrderRepositoryCustomImpl implements OrderRepositoryCustom {
private final EntityManager em;
@Override
public List<Order> findAllByString(OrderSearch orderSearch) {
//TODO 구현
}
}3) 1)에서 만든 인터페이스를 Spring Data JPA 리포지토리 인터페이스를 상속한 곳에 똑같이 상속해주십시오!
public interface OrderRepository extends JpaRepository<Order, Long>, OrderRepositoryCustom {
...
}해당 설명은 영한님의 실전! 스프링 데이터 JPA 강의에 나오는 부분이니 참고하시면 이해에 도움이 되실 것 같습니다!
감사합니다.
강의 관련 외 질문입니다.
0
68
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
0
92
1
BeanCreationException
0
91
3
Update 후 UpdateMemberResponse 매핑할 때
0
50
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
101
2
페이징 + 검색조건 관련해서 질문드립니다.
0
70
1
Query Dsl Q파일 질문입니다.
0
84
1
루트 쿼리라는것은
0
60
1
메서드를 분리하는 기준
0
65
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
111
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
86
2
fetch join과 영속화와 OSIV의 관계
0
87
2
Distinct 사용 전 결과에 대한 의문
0
117
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
59
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
78
2
dto 필드 속 엔티티 여부
0
60
1
뷰템플릿 사용 시
0
77
2
Result 클래스 관련 질문
0
56
1
@PostConstruct 프록시 관련 질문드립니다
0
86
1
DTO 대신 Form 사용은 안되나요?
0
138
1
OSIV ON 상태일 때
0
96
1
fetch join VS fetch join 페이징 궁금증
0
187
2
양방향 연관관계 알아보는 법?
0
106
1
16강 17강 간단 정리 이게 맞을까요 ?
0
166
2





