inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

단방향 연관관계

JPA에서 DB에 쿼리가 나가는 것 질문

355

김연규

작성한 질문수 11

0

안녕하세요 재밌게, 듣고 공부하고 있습니다. 감사합니다. 

다름이 아니라, 아래 코드에서 제 생각에는 change TEAM할 때, DB에 쿼리가 안나가더라구요??  teamB에 대한 내용을 DB에서 가져올 것으로 생각했거든요. 왜냐하면 영속성 컨텍스트에 없으니까 DB에서 가져와서 1차캐시에 넣는다 라고 생각했습니다. 

하지만 다시 생각해보니, 위에 teamB 객체를 이미 만들어두었기 때문에 이를 changeTeam 할때 넣으니까 쿼리가 DB에 안나가는 것 같습니다. 

 

그러면 commit 할때, update를 치잔아요??  그때, MEMBER 테이블에 변경된 TEAM 외래키를 넣을 텐데, 이때 JPA에서는 teamB의 키를 어떻게 아나요?? 영속성 컨텍스트에는 일단 teamB에 대한 내용은 없고, java 메모리에 teamB 있는 걸로 setTeam 하여 변경했는데, 업데이트 치려면 DB의 teamB의 키를 가져와야 할 텐데, 쿼리 나가는 것 보니 업데이트만 치더라구요... 

 

글이 길어졌네요... 답변 감사합니다! 

// 저장
Team teamA = new Team();
teamA.setName("TeamA");
em.persist(teamA);

// 저장
Team teamB = new Team();
teamB.setName("TeamB");
em.persist(teamB);

// 저장
Team teamC = new Team();
teamC.setName("TeamB");
em.persist(teamC);



Member member = new Member();
member.setName("member1");
member.setTeam(teamA);
em.persist(member);

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

// 조회
System.out.println("======find Member =====");
Member findMember = em.find(Member.class, member.getId());
System.out.println("======find Team Name ==== ");
System.out.println("findTeam = " + findMember.getTeam().getName());

// 팀 변경
System.out.println("======change TEAM =====");
findMember.setTeam(teamB);
System.out.println("======find Team Name ==== ");
System.out.println("findTeam = " + findMember.getTeam().getName());



tx.commit(); // 이때 DB에 query가 날라감






======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=? findTeam = TeamA ======change TEAM ===== ======find Team Name ==== findTeam = TeamB Hibernate: /* update hellojpa.Member */ update Member set USERNAME=?, TEAM_ID=? where MEMBER_ID=?

java JPA

답변 1

0

나무늘보

안녕하세요, 김연규 님. 공식 서포터즈 codesweaver 입니다.
.
최초 teabB를 생성하신 이후에 em.persist(teamB); 하신 순간 teamB에는 디비에서 얻어온 아이디 값이 들어오게 됩니다.

.

findMember.setTeam(teamB);. 했을때 쿼리가 날아가지 않는 부분은 말씀하신것처럼, 더티체킹은 트랜잭션이 끝나는 순간 발생하기 때문이지요.

.

트랜젹션이 끝나 실제로 업데이트를 하려 할 때, teamB 는 이미 고유한 아이디를 가지고 있으므로 문제없이 디비에 입력이 되는것입니다.

.
감사합니다.

벌크연산에서 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