작성
·
61
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
예
[질문 내용]
-영상강의: 플러시 4분30초 부분
<1차 시도>
: 원하던 결과값을 얻을 수 있었습니다.
(선 위로 콘솔찍힘)
<2차 시도>-id: 150L은 이미 2번 find 검사 진행한 상태
: flush()를 하지 않아도 결과 콘솔에는 선 위로 find결과가 출력됨.
질문: 1차 캐시 생명주기= 1번의 비즈니스 로직 이라고 설명해주셨는데(영상에서) 1번의 main문 실행이 1번의 로직이 인줄 알았어요. 정확히 1번의 비즈니스 로직이 어떤걸까요? (+ 위 사진 상황에서 캐시가 제거되는 시점을 어떻게 만들면 나타날까요?)
답변 2
1
안녕하세요. DongHyunKim님, 공식 서포터즈 y2gcoder입니다.
제가 DongHyunKim 님의 말씀을 제대로 이해했는지는 모르겠습니다.
1차 캐시 혹은 영속성 컨텍스트는 트랜잭션 단위로 생성된다고 보시면 좋을 것 같습니다. 저희 강의 코드를 기준으로 말씀드리자면 main 메서드를 실행할 때마다 새로 생성된다고 말씀드릴 수 있을 것 같습니다 🙂
첫번째 캡처는 멤버 엔티티를 만들고 저장하는 로직입니다. 원래라면 멤버 엔티티를 실제 DB에 저장하는 INSERT SQL 문은 트랜잭션 커밋(tx.commit()) 시에 flush가 발생하면서 쓰기 지연 SQL 저장소에서 DB로 나가게 될 것입니다. 그런데 중간에 수동으로 flush()를 해주었기 때문에 INSERT SQL이 출력문 이전에 나가게 되었습니다.
두번재 캡처에서는 main 메서드 실행시 영속성 컨텍스트를 만들게 됩니다. 그러면 빈 영속성 컨텍스트(1차 캐시)입니다. 이 때 em.find(Member.class, 150L)
을 해주면 JPA는 먼저 영속성 컨텍스트 내에서 id가 150인 Member 엔티티를 조회하려고 합니다. 근데 빈 영속성 컨텍스트이기 때문에 조회할 수 없습니다. 그래서 DB로 select 문을 보내 DB에 저장된 Member 데이터가 있는지 확인합니다. 그래서 이번에도 출력문 이전에 find 결과가 나오게 됩니다.
이를 바탕으로 답변을 드리자면 두번째 캡처에서는 시작부터 1차 캐시가 비어있는 상황입니다.
감사합니다.
0
감사합니다 "main 메서드를 실행할 때마다 새로 생성된다" 제가 듣고 싶었던 말을 정확히 해주셨습니다.