강의

멘토링

커뮤니티

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

kaka님의 프로필 이미지
kaka

작성한 질문수

실전! 스프링 데이터 JPA

벌크성 수정 쿼리

영속성컨텍스트 초기화 관련 질문

작성

·

81

1

삭제된 글입니다

답변 1

2

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. akffkd님 좋은 질문입니다.

1차 캐시의 내용이 데이터베이스에 flush() 되는 경우는 다음과 같습니다.

1. 트랜잭션 커밋

2. JPQL 실행

벌크연산도 JPQL 실행이기 때문에 벌크연산 실행 직전에 1차 캐시의 내용이 데이터베이스에 먼저 반영이 됩니다. 그래서 1차캐시와 데이터베이스의 데이터가 동기화 된 다음에 벌크 연산이 수행됩니다.

그런데 이렇게 하더라도 1차 캐시의 내용을 이후에 다시 변경하게 되면, 데이터베이스와 상태가 맞지 않을 수 있습니다.

그래서 이런 상황이 우려되면 벌크연산 이후에 영속성 컨테스트의 내용을 모두 지우는 것이 좋습니다. (스프링 데이터 JPA는 해당 옵션을 제공합니다.)

도움이 되셨길 바래요^^

kaka님의 프로필 이미지
kaka

작성한 질문수

질문하기