작성
·
204
0
Team team = new Team();
team.setId(1L);
team.setName("t1");
em.persist(team);
Member mem1 = new Member();
mem1.setName("aaa");
mem1.setTeam(team);
em.persist(mem1);
Member mem2 = new Member();
mem2.setName("bbb");
mem2.setTeam(team);
em.persist(mem2);
Member mem3 = new Member();
mem3.setName("ccc");
mem3.setTeam(team);
em.persist(mem3);
em.clear();
em.flush();
// Team newTeam = em.find(Team.class, 1L);
// System.out.println(newTeam.toString());
// List<Member> ML = newTeam.getMembers();
// System.out.println("test:"+ML.get(0).getName());
Member newMember = em.find(Member.class, 1L);
System.out.println("test:"+newMember.getTeam().getName());
tx.commit();
1:N관계인 Team Member를 DB에서 가져올때 서로 양방향 연관관계인 경우
Team에서는 join없이 2번의 쿼리를 날려서 조회하고
Member에서는 외래키를 사용하여 join문으로 1번의 쿼리로 조회를 하더라구요.혹시 이 두가지가 왜 이런 차이가 나는지 알 수 있을까요?
Team에서 Member를 가져올때 충분히 기본키를 활용하여 가져올 수 있을텐데요
조민준님 답변 감사합니다^^