인프런 커뮤니티 질문&답변

wldbs1944님의 프로필 이미지
wldbs1944

작성한 질문수

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

프로젝션(SELECT)

4:40 영속성 컨텍스트 상태

작성

·

250

0

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

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

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

[질문 내용]
여기에 질문 내용을 남겨주세요.
4:40 쯤 코드 상황에서
em.persist(member) 를 한 후 플러시 클리어 하면 영속성 컨텍스트가 비게 되고 그 후 에 쿼리를 날리면서 db를 조회해서 memberList에 저장한다고 이해했는데
commit 하지 않았으니까 아직 db에 member에 관한 데이터가 없는거 아닌가 하는 생각이 들었습니다
1. 영속성 컨텍스트에서 쿼리로 조회한 데이터를 관리한다고 하셨는데 플러시 클리어했는데 어떻게 영속성 컨텍스트에 쿼리로 조회한 데이터가 있는지 궁금합니다.
2. 데이터가 없는데 조회를 할 수 있는게 궁금해서 어느 부분을 제가 잘 못 이해한건지 궁금합니다
 
Member member = new Member();
member.setAge(10);
member.setUsername("홍길동");
em.persist(member);

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

List<Member> memberList = em.createQuery("select m from Member m").getResultList();

Member findMember = memberList.get(0);
findMember.setAge(20);

답변 1

0

1. flush를 하게 되면 영속성 컨텍스트에 저장된 데이터를 commit 하게 됩니다.

이때, DB에 쿼리를 날려 member 정보를 저장하게 됩니다. 콘솔창을 보면 insert 쿼리가 나가는 걸 확인할 수 있습니다.

1차 캐시에 이미 member가 저장이 되어 있으니 clear를 통해 모두 비워줍니다.

 

2. 위에서 member 정보가 DB에 저장이 되었으니 이제 DB에서 조회가 가능합니다.

 

em.flush() 와 em.clear()가 무엇인지 찾아 보시면 바로 이해가 되실 것 같아요.

직접 메서드를 하나씩 실행해 보고 확인해 보시길 추천드립니다!

wldbs1944님의 프로필 이미지
wldbs1944

작성한 질문수

질문하기