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

Umi님의 프로필 이미지
Umi

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

즉시 로딩과 지연 로딩

Spring boot Service 레이어 등등에서 지연 로딩 사용 시 질문이 있습니다.

작성

·

393

0

안녕하세요. 영한님 강의 잘 수강하고 있습니다!

강의 수강 도중 실무에 적용하면서 오류가 하나 있어 조언을 구하고자 글을 씁니다.

JPA와 Spring boot를 사용 중인데요. 서비스 계층에서 jpa repository를 사용할 때 proxy 객체에 세션이 없다는 오류를 겪게 되었습니다. 알아보니 Eager loading을 하거나 @Transaction annotation을 서비스 계층 메소드에 붙여주라는 것이었는데요.

아마 @Transaction 어노테이션을 붙여주면 트랜잭션과 영속성 컨텍스트가 살아있고, 따라서 제가 첨부하는 예시에선 List<Bar> bars에 대한 프록시의 세션이 살아있기 때문에 Lazy loading이 가능해지는 게 아닌가 싶구요. Eager loading은 당연히 오류 없이 수행은 되는 것 같습니다.

( 참고: https://stackoverflow.com/a/41140986/9471220 )

혹시 Repository 계층보다 상위에서 Lazy loading 필드에 접근하면 어떤 방법이 베스트일까요? 지금 생각 중인 방법은 Lazy loading 필드에 접근하는 모든 메소드에서 @Transaction을 명시해주는 것인데, 이 경우 너무 많은 Transaction 생성으로 인한 오버헤드 같은 것은 없을 지 걱정됩니다.

감사합니다.

답변 1

0

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

안녕하세요. Umi님

실무에서는 fetch join을 적극적으로 사용합니다.

그러면 쿼리 수도 줄일 수 있고, 해당 부분에 지연로딩이 발생하지도 않습니다.

추가로 지연 로딩을 사용해야 하는 경우에는 @Transaction을 사용하거나 또는 OSIV를 사용해야 합니다.

고민하시는 부분들은 활용2편에서 주로 다루고 있으니 다음 활용2편을 참고해주세요.

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

감사합니다.

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

아직 fetch join쪽을 수강하지 않은 탓이었나보군요.. 감사드립니다!!

Umi님의 프로필 이미지
Umi

작성한 질문수

질문하기