• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

벌크 연산

23.07.18 23:57 작성 조회수 187

0

... (위에 기존의 코드를 반영 member1,2,3 나이 별도로 설정하지 않음 '0' 현재 persist를 통해 영속성 컨텍스트에 존재하는 상황)

int resultCount = em.createQuery("update Member m set m.age = 20")
.executeUpdate();

em.clear();

Member findMember = em.find(Member.class, member1.getId());
System.out.println("findMember.getAge() = " + findMember.getAge());

System.out.println("resultCount = " + resultCount);

System.out.println("member1.getAge() = " + member1.getAge());
System.out.println("member2.getAge() = " + member2.getAge());
System.out.println("member3.getAge() = " + member3.getAge());


int resultCount = em.createQuery("update Member m set m.age = 20")
.executeUpdate();

이 부분은 영속성 컨텍스트와 상관 없이 DB에 바로 적용 된다고 알고 있습니다.

em.clear();

하게되면 영속성 컨텍스트를 비우게 되고,

Member findMember = em.find(Member.class, member1.getId());
System.out.println("findMember.getAge() = " + findMember.getAge());

를 하게되면 update를 통해 DB에 저장된 값을 DB에서 불러서 영속성 컨텍스트에 저장하고 해당 값을 가져오고,

System.out.println("resultCount = " + resultCount);

이 값은 위에서 update를 통해 3개가 update 되었기 때문에 3이란 값이 저장되어 나오고,

  • (궁금한 부분)

System.out.println("member1.getAge() = " + member1.getAge());
System.out.println("member2.getAge() = " + member2.getAge());
System.out.println("member3.getAge() = " + member3.getAge());

이 부분의 경우 그냥 메모리에 저장된 값을 가져오는 것이 맞나요? 디버깅을 해보기 이전에 메모리에 생성했던 값을 다시 가르키는 것 같지만 확실한지 모르겠어서 질문 남깁니다...

답변 1

답변을 작성해보세요.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2023.07.21

안녕하세요, 인프런 AI 인턴이에요.

위 코드에서 “member1.getAge()“를 출력하는 부분에서 “member1”은 어디서 왔는지 명확하게 확인할 수 없습니다. 코드 일부가 누락된 것 같습니다.

영속성 컨텍스트는 변경된 엔티티를 추적하고, 변경사항을 데이터베이스에 동기화하는 데 사용됩니다. em.clear() 메서드를 호출하면 영속성 컨텍스트가 초기화되고, 이후 findMember = em.find(Member.class, member1.getId()) 코드로 해당 멤버의 상태를 데이터베이스에서 다시 조회합니다. 따라서, findMember.getAge()를 호출하면 실제 데이터베이스에 저장된 값이 출력됩니다.

하지만, “member1.getAge()“는 member1 객체의 상태를 출력하는 코드로 보이기 때문에 영속성 컨텍스트의 상태를 출력하는 것이라면, 위에서 update된 값이 출력되어야 합니다. 이 부분이 코드의 목적과 일치하는지 확인이 필요합니다. 만약 영속성 컨텍스트의 상태를 출력하고 싶다면, em.clear()를 호출하지 않고 member1 객체의 상태를 조회해야 합니다.

더 자세한 답변을 원하시거나 코드가 완전하지 않아 추가 질문이 필요하시다면, 질문 내용을 보완해 주세요. 감사합니다.