작성
·
298
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
안녕하세요. 제가 실습해보다가 궁금한 부분이 생겨서 질문드립니다.
public class JpaMain {
public static void main(String[] args){
EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");
// persistence.xml에 있는 <persistence-unit name="hello">애서 name이 hello니깐 createEntityManagerFactory("hello")에 hello 넣어줘야함
EntityManager em = emf.createEntityManager();
// 밑의 close() 이전에 할 거 다하고 close()로 entitymanager랑 entityManagerFactory 닫음
EntityTransaction tx = em.getTransaction();
try{
tx.begin();
Team team = new Team();
team.setName("teamA");
em.persist(team);
Member member = new Member();
member.setUsername("member1");
member.setTeam(team);
em.persist(member);
Member member2 = new Member();
member2.setUsername("member2");
em.persist(member2);
//
em.flush();
em.clear();
Member findmemeber = em.find(Member.class,member.getId());
List<Member> findmembers = findmemeber.getTeam().getMembers();
System.out.println(team);
System.out.println(findmemeber.getTeam());
tx.commit();
} // transection을 열고 코드를 수행하고 transaction을 닫음
catch (Exception e){
System.out.println(e);
tx.rollback();
} // 에러나면 transaction 롤백
finally{
em.close();
}
// tx.begin() ~ tx.commmit()은 transaction단위, JPA는 데이터베이스에 대한 작업시 트랜잭션 작업단위로 해야한다.
emf.close();
}
}
이렇게 코드를 쳐봤는데
System.out.println(team)과
System.out.println(findmember.getTeam())
이
jpabook.jpashop.domain.Team@2b34e38c
jpabook.jpashop.domain.Team@5633ed82
으로 다른 인스턴스가 출력이 되는 걸 확인했습니다.
제 생각에는 member.setTeam(team)을 했기 때문에 같은 인스턴스가 나올 것이라고 생각했는데 왜 다른 인스턴스가 나오게 되는 것인지 궁금합니다.
답변 2
0
안녕하세요, 인프런 AI 인턴입니다.
재윤님의 질문과 유사한 경우로, team
객체와 findMember.getTeam()
이 다른 인스턴스로 나오는 현상에 대해 궁금해 하시는 내용을 확인해보시면 도움이 될 것 같습니다.
같은 인스턴스가 나와야 할 것 같지만, JPA의 영속성 컨텍스트 초기화(em.clear()) 이후에 데이터를 다시 로딩할 때 새로운 인스턴스가 생성되기 때문에 다르게 보이는 것입니다.
아래 링크에서 더 자세한 설명을 확인하실 수 있습니다.
해당 내용을 참고하여 em.clear()
이후에 조회된 엔티티 객체와 초기에 생성한 엔티티 객체의 인스턴스가 다르게 출력되는 원인을 이해하시면 좋을 것 같습니다.