쓰기지연저장소 쿼리 저장 시점 관련 질문드립니다.
90
작성한 질문수 108
강의 내용에서, 트랜잭션 커밋전에 em.persist나 em.remove를 하면, 영속성컨텍스트의 1차캐시에 값이 저장 또는 삭제되고, 쿼리를 생성해서 쓰기지연저장소에 저장한다고 하셨는데요.
트랜잭션 커밋전에 쿼리를 생성해서 쓰기지연저장소에 저장하는것인가요? 아니면 트랜잭션 커밋 이후 내부적으로 flush()호출 시 쿼리를 생성해서 쓰기지연 저장소에 저장하는것인가요??
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. 오리쉐리님.
JPA에서의 쓰기 지연 저장소와 관련된 질문을 주셨네요. 이 개념은 JPA의 트랜잭션 관리와 깊은 연관이 있으며, 실제로 여러 궁금증을 불러일으킬 수 있는 부분입니다. 요약하여 설명드리겠습니다.
쓰기 지연 저장소는 JPA에서 영속성 컨텍스트의 한 기능으로, 기본적으로 INSERT, UPDATE, DELETE 쿼리를 트랜잭션 커밋 시점까지 모아두는 역할을 합니다. 이는 트랜잭션의 성능을 향상시키기 위한 전략입니다.
em.persist()나 em.remove() 호출 시점:
- 해당 메소드를 호출하면 영속성 컨텍스트에 엔티티가 영속 상태로 저장되거나 삭제 준비 상태가 됩니다. 이 때, 즉시 쿼리가 데이터베이스로 전송되지 않고, 쓰기 지연 저장소에 쿼리가 저장됩니다.
- 해당 메소드를 호출하면 영속성 컨텍스트에 엔티티가 영속 상태로 저장되거나 삭제 준비 상태가 됩니다. 이 때, 즉시 쿼리가 데이터베이스로 전송되지 않고, 쓰기 지연 저장소에 쿼리가 저장됩니다.
트랜잭션 커밋 시점:
- 트랜잭션을 커밋할 때, JPA는 자동으로
flush()를 호출합니다. 이 과정에서 쓰기 지연 저장소에 모여 있던 쿼리들이 데이터베이스로 전송되고 실행됩니다.
- 트랜잭션을 커밋할 때, JPA는 자동으로
따라서, 트랜잭션 커밋 전에 쿼리가 생성되어 쓰기 지연 저장소에 저장되는 것이 맞습니다. 트랜잭션 커밋 시, 즉 flush() 호출 시, 이미 저장된 쿼리들이 데이터베이스로 전달되어 실행됩니다.
추가적인 정보를 위해, 아래 링크에서 관련 질문과 답변을 확인해 보시면 더욱 도움이 되실 겁니다:
- JPA 1차 캐시와 쓰기지연 DB 질문 드립니다.: persist와 flush의 동작 방식과 쓰기 지연 저장소의 역할에 대해 자세히 설명합니다.
- 1차캐시와 SQL 쓰기지연 저장소에 저장되는 시점이 궁금합니다.: 1차 캐시와 쓰기 지연 저장소 간의 관계를 설명합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?
0
33
2
inheritance startegy 선택시 고려사항
0
24
1
Entity 동등성 비교
0
24
1
실무 조언 관련 질문입니다.
0
48
1
H2데이터베이스 파일 생성
0
59
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
57
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
58
1
JPQL 메소드와 락
0
56
1
Delivery @OneToOne
0
62
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
98
2
UnsupportedOperationException 발생
0
87
3
H2 Database 연결이 안됩니다.
0
98
2
연관관계 매핑 질문드립니다.
0
88
2
h2데이터베이스 실행오류
0
110
2
persistence.xml
0
112
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
83
1
영속성 컨텍스트
0
69
1
JPA 프록시
0
98
1
Native Query와 MyBatis
0
72
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
93
1
임베디드 타입 예시 코드 관련 질문
0
121
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
96
3
인텔리제이 패키지 커서 단축키 질문
0
109
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
149
1





