inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

조인

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

480

shake_sphere

작성한 질문수 3

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혹시 어디 부분에서 이런 상황이 계속 발생하는지 알 수 있을까요?

JPA java

답변 1

1

김영한

안녕하세요. shake_sphere님

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

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

https://bit.ly/3fX6ygx

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

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

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

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

감사합니다.

0

shake_sphere

답변주셔서 감사합니다!

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

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

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

0

김영한

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

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

29

2

inheritance startegy 선택시 고려사항

0

23

1

Entity 동등성 비교

0

22

1

실무 조언 관련 질문입니다.

0

47

1

H2데이터베이스 파일 생성

0

56

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

53

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

55

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

94

2

UnsupportedOperationException 발생

0

86

3

H2 Database 연결이 안됩니다.

0

96

2

연관관계 매핑 질문드립니다.

0

86

2

h2데이터베이스 실행오류

0

108

2

persistence.xml

0

109

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

82

1

영속성 컨텍스트

0

67

1

JPA 프록시

0

98

1

Native Query와 MyBatis

0

71

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

88

1

임베디드 타입 예시 코드 관련 질문

0

115

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

95

3

인텔리제이 패키지 커서 단축키 질문

0

108

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

146

1