• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

JPQL inner join에서 Team을 LAZY로 설정해도 같은 이슈발생에 대해서 문의드립니다.

22.11.22 21:46 작성 조회수 336

0

안녕하세요 김영한님!

좋은 강의 제공해주셔서 진심으로 감사합니다.

다름이아니라 JPQL inner join으로 Member, Team 조인했을 때 inner join에서 추가로 team select 쿼리가 나가는 부분에서 이슈가 있어서 문의드리게 되었습니다.

저는 kotlin으로 강의내용 코드를 작성해서 공부하고 있는데요.

val resultList = em.createQuery("select m from Member m join m.team t", Member::class.java)
            .resultList

강의내용대로 inner join JPQL 작성했고 Member Entity는

@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "team_id")
var team: Team? = null

이렇게 LAZY로 설정하고 코드 실행했는데 team select 쿼리가 여전히 inner join 쿼리 이후에 추가로 실행되고 있었는데요.

Screenshot 2022-11-22 at 9.48.30 PM.png혹시 어디 부분에서 이런 상황이 계속 발생하는지 알 수 있을까요?

답변 1

답변을 작성해보세요.

1

안녕하세요. shake_sphere님

전체 프로젝트를 자바로 다시 만들고 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx

주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요

추가로 다음 내용도 코멘트 부탁드립니다.

1. 실행 방법을 알려주세요.

2. 어떻게 문제를 확인할 수 있는지 자세한 설명을 남겨주세요.

감사합니다.

답변주셔서 감사합니다!

한 번 찾아봤는데요 강의 자체 코드 문제가 아니고 코틀린 언어 자체의 문제였습니다!

코틀린이 자바에서 기본적으로 final 필드로 변환되다 보니 LAZY로 설정해도 proxy자체를 생성하지 못하는 이슈였던 것 같습니다.

자바코드로도 확인해보고 코틀린에서 Member 엔티티의 모든 프로퍼티를 open으로 해서 상속가능하도록 하니까 강의 내용대로 team 검색쿼리 안나가고 inner join만 된 것을 확인했습니다.

shake_sphere님 자세히 남겨주셔서 감사합니다^^ 다른 분들께도 도움이 되겠네요