스프링 데이터 JPA에서 커스텀 리포지토리 OSIV 관련
325
작성한 질문수 2
OSIV -> false로 설정하면
컨트롤러에서 DTO로 변환할 때, 지연 로딩이 발생하면
LazyInitializationException 발생하는 것으로 이해했습니다.
그래서 리포지토리에서 직접 DTO로 변환한 뒤 컨트롤러로 보내주려고 하는데요!
그런데 스프링 데이터 리포지토리는 인터페이스이기 때문에 [엔티티 -> DTO]코드를 넣지 못해서 커스텀 리포지토리의 구현체 (OrderRepositoryCustomImpl.class)에 다음과 같이 메서드를 넣었습니다.
public List<OrderDto> findOrderDtos() {
List<Order> orders = queryFactory
.selectFrom(order)
.fetch();
List<OrderDto> result = orders.stream()
.map(o -> new OrderDto(o))
.collect(Collectors.toList());
return result;
}
코드를 실행하니 여전히 LazyInitializationException이 발생하네요 ㅜㅜ
1. 스프링 데이터 JPA 구현체에 기본적으로 @Transactional(readOnly = true)가 적용되어 있는 것으로 알고 있는데, 커스텀 구현체에까지 전파되지 않는건가요??
2. 만약 이렇게 OSIV -> false + DTO로 변환하는 과정(지연로딩)이 필요하다면 꼭 인터페이스가 아닌 클래스 구현체에서 쿼리를 날려야 할까요? @EntityGraph같은 스프링 데이터의 좋은 애노테이션들을 함께 사용하고 싶어서요
DTO를 Service에서 변환하는 방법도 있을텐데 간단한 기능들은 리포지토리에서 바로 DTO를 보내려고 합니다.
답변 2
0
아하 트랜잭션을 별도로 설정해주어야하는군요!! 감사합니다.
생각해보면 Querydsl로 DTO를 바로 뽑는게 더 편하겠네요..ㅎㅎ;;
강의 마지막쯤에
1. 엔티티 -> DTO 방법을 우선적으로 생각하고
2. 그래도 안되면 DTO로 바로 조회하는 방식을
권장한다고 하셔서 1번 방식에 꽃혀있었던것같습니다.
그럼 위와 같이 리포지토리에서 바로 DTO를 넘기는 경우에는 2번 방식을 사용하는 것이 편리할까요?
혹은 리포지토리에서 서비스로 엔티티를 넘긴후 서비스에서 DTO를 넘겨도 좋을것같네요..!
0
안녕하세요. gksdudrb922님
스프링 데이터 JPA에서 트랜잭션을 제공하는 것은 SimpleJpaRepository 구현체가 제공하는 기능만 적용됩니다.
커스텀을 직접 구현하는 곳에는 트랜잭션도 별도로 달아주셔야 합니다.
JPA의 new 명령어를 사용해서 인터페이스에서 직접 DTO로 바로 조회하는 방법도 있습니다. 이 부분은 스프링 데이터 JPA 강의를 참고해주세요.
그런데 나중에는 결국 DTO로 조회하는 부분은 Querydsl을 사용해서 구현 클래스에서 사용하는 방법을 선호하게 되실거에요.
감사합니다.
@JsonIgnore 이후 Internal Server Error가 발생하지 않습니다.
0
30
2
강의 관련 외 질문입니다.
0
91
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
1
111
1
BeanCreationException
0
103
3
Update 후 UpdateMemberResponse 매핑할 때
0
64
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
109
2
페이징 + 검색조건 관련해서 질문드립니다.
0
76
1
Query Dsl Q파일 질문입니다.
0
92
1
루트 쿼리라는것은
0
68
1
메서드를 분리하는 기준
0
76
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
122
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
97
2
fetch join과 영속화와 OSIV의 관계
0
100
2
Distinct 사용 전 결과에 대한 의문
0
124
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
65
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
82
2
dto 필드 속 엔티티 여부
0
67
1
뷰템플릿 사용 시
0
85
2
Result 클래스 관련 질문
0
59
1
@PostConstruct 프록시 관련 질문드립니다
0
91
1
DTO 대신 Form 사용은 안되나요?
0
142
1
OSIV ON 상태일 때
0
102
1
fetch join VS fetch join 페이징 궁금증
0
192
2
양방향 연관관계 알아보는 법?
0
113
1





