해결된 질문
작성
·
82
0
엔티티 매니저 팩토리
사용자가 설정한 정보에 따라 엔티티 매니저 팩토리를 생성합니다. 이 엔티티 매니저 팩토리는 오직 애플리케이션이 실행될 때 하나만 존재해야 합니다. 엔티티 매니저 팩토리의 주요 기능은 엔티티 매니저를 생성하는 겁니다. 사용자의 요청이 디비로 쿼리를 보내는 경우라면 요청과 1:1로 매핑 되는 엔티티 매니저를 생성합니다.
엔티티 매니저
엔티티 매니저의 핵심 기능은 엔티티를 관리하는 것입니다.엔티티 매니저에는 영속성 컨텍스트라는 논리적 공간이 존재합니다. 여기서 엔티티를 관리합니다.
저장
persist()를 할 경우 엔티티 매니저에 엔티티를 저장합니다. 이때 1차 캐시에 키는 엔티티의 pk값, 값은 엔티티를 값으로 저장 합니다. 저장 시 전략이 identity인 경우 insert 쿼리를 DB로 바로 전송합니다. 그 외는 쓰기 저장소에 보관합니다.
조회
find()를 할 경우 처음에는 1차 캐시에서 조회하고 없으면 DB에서 조회합니다. 주의할점은 즉시로딩과 지연로딩입니다.
즉시로딩은 A 조회시 A와 연관관계에 있는 데이터들도 한번에 조회하는 방식입니다.
지연로딩은 A 조회 후 A와 연관관계에 있는 데이터 사용 시 조회하는 방식입니다.
수정
더치 체킹 덕분에 값만 변경해도 JPA가 알아서 update 쿼리를 보냅니다.
플러시
플러시가 발생 시 우선 더티 체킹이 발생합니다.
값이 변경된 부분이 있으면 update, delete 쿼리를 생성하여 쓰기 저장소에 저장합니다.
더티 체킹이 끝나면 쓰기 저장소에 보관했던 SQL문들을 DB로 한번에 전송합니다.
쓰기 저장소
em.persist()에 의해 발생한 insert 쿼리
더디 체킹에 의해 발생한 update 쿼리
em.remove()에 의해 발생한 delete 쿼리
위 상황에서 발생한 쿼리들을 보관하는 저장소입니다.
플러시 발생 시 위 쿼리들을 DB에 한번에 전송합니다.
감사합니다.
답변 2
0
안녕하세요. 감바스님
정리하신 내용이 맞습니다.
추가로 이 엔티티 매니저 팩토리는 오직 애플리케이션이 실행될 때 하나만 존재해야 합니다.
-> 이 부분은 지금은 이렇게 이해하셔도 괜찮습니다. 데이터베이스가 여러개라면 엔티티 매니저 팩토리도 여러개 존재할 수 있습니다.
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다.
감바스님께서 정리하신 내용에 대해 질문하셨군요. JPA와 관련해 엔티티 매니저, 영속성 컨텍스트, 즉시 로딩과 지연 로딩, 플러시와 쓰기 지연 저장소 등 여러 중요한 개념들을 포함하시며 정리하신 것 같습니다. 정리하신 내용은 JPA의 주요 개념들을 잘 반영하고 있습니다.
제공된 정보 중에서, 감바스님의 질문에 가장 적합한 내용을 찾아보겠습니다:
영속성 컨택스트에 대한 이해: 이 질문은 영속성 컨텍스트의 기본적인 이해와 관련된 질문입니다. 감바스님께서 언급하신 엔티티 매니저와 영속성 컨텍스트의 관계, 질문에서 나타나는 엔티티의 생명주기와 관리 방법에 대해 설명하고 있습니다.
영속성 컨텍스트 및 flush에 대한 궁금증 입니다.: 이 게시물에서는 persist와 flush의 시점 및 영향에 관해 자세히 설명하고 있으며, 감바스님의 질문에 관한 ‘저장’, ‘조회’, ‘수정’, 그리고 ‘플러시’부분에 대한 설명이 포함되어 있습니다.
스프링부트 내에서 JPA 1차 캐시의 라이프 사이클에 대한 질문입니다.: 여기서는 1차 캐시와 관련된 질문으로, 트랜잭션과 영속성 컨텍스트간의 관계가 설명되어 있습니다. 감바스님께서 언급한 ‘저장’과 ‘조회’ 과정에서의 1차 캐시의 역할과 관련있습니다.
감바스님께서 정리하신 내용은 JPA의 핵심적인 부분들을 잘 반영하고 있으며, 위의 링크들을 통해 관련 개념의 보강 및 이해를 심화할 수 있을 것입니다. 각 링크는 특정한 JPA의 처리 과정과 관련된 구체적인 질문들에 대한 답변을 포함하고 있어, 감바스님의 이해도를 높이는 데 도움이 될 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.