inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

엔티티 직접 사용

엔티티 직접사용 외래키 값에 대한 결과 값이 기대한 것과 다릅니다.

344

Na Seunghoo

작성한 질문수 7

0

안녕하세요 

엔티티 직접사용 - 외래키 값에 대해 기대한   쿼리 실행이 다른데 어떤 이유인지 모르겠습니다. 

Team team = new Team();
team.setName("TeamA");
em.persist(team);


Member member = new Member();
member.setUsername("MemberA");
member.setTeam(team);
em.persist(member);

em.flush();
em.clear();

Member resultMember = em.createQuery("SELECT m FROM Member m WHERE m.team = :teamId", Member.class)
.setParameter("teamId",team)
.getSingleResult();

System.out.println("resultMember= " + resultMember);

위와 같이 실행했을 때 ]

Hibernate: 

    /* SELECT

        m 

    FROM

        Member m 

    WHERE

        m.team = :teamId */ select

            member0_.MEMBER_ID as MEMBER_I1_4_,

            member0_.CreateDate as CreateDa2_4_,

            member0_.createBy as createBy3_4_,

            member0_.lastModifyBy as lastModi4_4_,

            member0_.lastModifyDate as lastModi5_4_,

            member0_.enDateTime as enDateTi6_4_,

            member0_.stDateTime as stDateTi7_4_,

            member0_.TEAM_ID as TEAM_ID9_4_,

            member0_.USERNAME as USERNAME8_4_ 

        from

            Member member0_ 

        where

            member0_.TEAM_ID=?

Member 엔티티에 대한 쿼리만 발생할 줄 알았는데 

Hibernate: 

    select

        team0_.TEAM_ID as TEAM_ID1_8_0_,

        team0_.name as name2_8_0_ 

    from

        Team team0_ 

    where

        team0_.TEAM_ID=?

아래와 같이 Team에 대한 조회가 한번더 일어나게 됩니다. 

7분 19 초에 대한 실행된 SQL과 다른데 이유가 무엇일까요 ?! 

JPA java

답변 1

0

김영한

안녕하세요. Na Seunghoo님

Member -> Team의 연관관계에 지연로딩이 설정되어 있는지요? 아니면 즉시로딩이 설정되어 있는지요?

참고로 @ManyToOne 관계는 기본이 즉시로딩입니다.

즉시로딩이 설정되어 있다면 JPQL은 Member만 조회해야 하는데, Member -> Team의 설정이 즉시로딩이 이기 때문에, 즉시 로딩을 위해 추가 쿼리가 발생합니다.

실무에서는 모든 연관관계는 지연로딩으로 설정하시길 권장드립니다.

만약에 즉시로딩이 아니라 지연로딩으로 설정되어 있다면, 어디에선가 team을 초기화 하고 있을거에요. 이 부분을 확인해보아야 합니다.

감사합니다.

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

0

39

1

H2데이터베이스 파일 생성

0

48

2

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

0

49

2

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

0

46

1

JPQL 메소드와 락

0

48

1

Delivery @OneToOne

0

55

1

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

0

85

2

UnsupportedOperationException 발생

0

80

3

H2 Database 연결이 안됩니다.

0

87

2

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

0

78

2

h2데이터베이스 실행오류

0

103

2

persistence.xml

0

101

2

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

0

75

1

영속성 컨텍스트

0

61

1

JPA 프록시

0

87

1

Native Query와 MyBatis

0

62

1

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

0

81

1

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

0

110

3

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

0

89

3

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

0

103

2

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

0

134

1

양방향 연관관계 시 연관관계 주인을 설정하는 이유

0

67

1

임베디드 타입과 MappedSuperClass의 차이점이 궁금합니다.

0

95

1

데이터베이스가 초기화되는 것 같아요

1

172

2