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

김연규님의 프로필 이미지
김연규

작성한 질문수

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

양방향 연관관계와 연관관계의 주인 1- 기본

DB에 나가는 쿼리 질문

작성

·

161

0

항상 감사합니다. 

 

아래 코드에서 

List<Member> members = findMember.getTeam().getMembers();

이 부분에 나가는 쿼리가 

Hibernate: 

    select

        team0_.TEAM_ID as TEAM_ID1_1_0_,

        team0_.name as name2_1_0_ 

    from

        Team team0_ 

    where

        team0_.TEAM_ID=?

 

이거 더라구요..

저는 List<Member> 니까 Member를 들고 올 거라고 생각했는데, select 문 보니 team 이었습니다... 

그러고 List<Member> 를 for 문으로 돌려보니 이제서야 select Member 쿼리가 나가더라구요.. 

왜 그렇죠..??

 

// 조회
System.out.println("======find Member =====");
Member findMember = em.find(Member.class, member.getId());
System.out.println("======find Team Name ==== ");
List<Member> members = findMember.getTeam().getMembers();
System.out.println("======print Team member ==== ");

for (Member m : members) {
System.out.println("m = " + m.getName());
}

System.out.println("======end ==== ");

======find Member =====

Hibernate: 

    select

        member0_.MEMBER_ID as MEMBER_I1_0_0_,

        member0_.USERNAME as USERNAME2_0_0_,

        member0_.TEAM_ID as TEAM_ID3_0_0_ 

    from

        Member member0_ 

    where

        member0_.MEMBER_ID=?

======find Team Name ==== 

Hibernate: 

    select

        team0_.TEAM_ID as TEAM_ID1_1_0_,

        team0_.name as name2_1_0_ 

    from

        Team team0_ 

    where

        team0_.TEAM_ID=?

======print Team member ==== 

Hibernate: 

    select

        members0_.TEAM_ID as TEAM_ID3_0_0_,

        members0_.MEMBER_ID as MEMBER_I1_0_0_,

        members0_.MEMBER_ID as MEMBER_I1_0_1_,

        members0_.USERNAME as USERNAME2_0_1_,

        members0_.TEAM_ID as TEAM_ID3_0_1_ 

    from

        Member members0_ 

    where

        members0_.TEAM_ID=?

m = member1

답변 1

0

안녕하세요, 김연규 님. 공식 서포터즈 codesweaver 입니다.
.
간단하게 말씀드리면, JPA는 성능 최적화를 위해 가능한한 쿼리를 늦게 보내려고 노력합니다. 그래서 어떤 객체를 요구할때 '가짜 객체'(프록시)를 일단 내어줍니다. 그러다가 클라이언트가 가짜객체로는 도저히 처리할 수 없는 데이터를 요구할경우 DB에 다녀옵니다. 

 

자세한 내용은 앞으로의 수업중 '프록시 연관관계 관리' 의 프록시와 지연로딩 파트에서 자세히 들으실 수 있습니다.
.
감사합니다.

 

김연규님의 프로필 이미지
김연규

작성한 질문수

질문하기