inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

페치 조인 2 - 한계

IN 쿼리 작동 시점에 바인딩 로직

170

도토리묵

작성한 질문수 5

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
@BatchSize 사용시 IN 쿼리 발생 시점에 과정이 궁금해서 질문 남깁니다.

Team teamA = new Team();
teamA.setName("teamA");
Team teamB = new Team();
teamB.setName("teamB");

em.persist(teamA);
em.persist(teamB);

User user1 = new User();
user1.setUsername("user1");
user1.setTeam(teamA);
em.persist(user1);

User user2 = new User();
user2.setUsername("user2");
user2.setTeam(teamA);
em.persist(user2);

User user3 = new User();
user3.setUsername("user3");
user3.setTeam(teamB);
em.persist(user3);

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

List<Team> result = em.createQuery("select t from Team t", Team.class)
        .getResultList();

System.out.println("==============================");
for (Team team : result) {
    System.out.println("team.getUsers().size() = " + team.getUsers().size());
}

result에서 조회된 team들의 team_id가 IN 쿼리의 파라미터로 바인딩되고 그에 해당하는 user 인스턴스들이 영속성 컨텍스트에 저장되는 것 까지는 알겠습니다.
그 이후에 이 user 인스턴스들이 어떻게 team의 users 컬렉션에 매핑되는 것인지가 궁금합니다.

java jpa

답변 1

0

김영한

안녕하세요. 도토리묵님

이 부분은 하이버네이트 내부에서 수행되는데요.

result에서 조회된 team들의 team_id가 IN 쿼리의 파라미터로 바인딩되고 그에 해당하는 user 인스턴스들이 영속성 컨텍스트에 저장되고 나서, user 인스턴스에는 team_id 값이 들어있습니다. 이 값이 결국 team의 @Id 값이기 때문에 이 값을 확인하면 본인이 어떤 team에 소속되어야 하는지 알 수 있습니다.

감사합니다.

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

0

36

2

inheritance startegy 선택시 고려사항

0

25

1

Entity 동등성 비교

0

25

1

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

0

52

1

H2데이터베이스 파일 생성

0

61

2

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

0

58

2

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

0

58

1

JPQL 메소드와 락

0

57

1

Delivery @OneToOne

0

64

1

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

0

98

2

UnsupportedOperationException 발생

0

89

3

H2 Database 연결이 안됩니다.

0

98

2

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

0

88

2

h2데이터베이스 실행오류

0

110

2

persistence.xml

0

113

2

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

0

83

1

영속성 컨텍스트

0

70

1

JPA 프록시

0

100

1

Native Query와 MyBatis

0

74

1

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

0

94

1

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

0

121

3

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

0

97

3

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

0

109

2

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

0

149

1