inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

DB에 나가는 쿼리 질문

202

김연규

작성한 질문수 11

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

java JPA

답변 1

0

나무늘보

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

 

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

 

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

0

54

2

inheritance startegy 선택시 고려사항

0

36

1

Entity 동등성 비교

0

38

1

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

0

64

1

H2데이터베이스 파일 생성

0

76

2

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

0

66

2

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

0

62

1

JPQL 메소드와 락

0

62

1

Delivery @OneToOne

0

70

1

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

0

104

2

UnsupportedOperationException 발생

0

97

3

H2 Database 연결이 안됩니다.

0

101

2

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

0

93

2

h2데이터베이스 실행오류

0

114

2

persistence.xml

0

119

2

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

0

87

1

영속성 컨텍스트

0

74

1

JPA 프록시

0

105

1

Native Query와 MyBatis

0

81

1

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

0

97

1

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

0

125

3

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

0

100

3

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

0

112

2

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

0

151

1