작성
·
93
·
수정됨
0
질문1)
한 트랜잭션 안에서 최초 getReference()
를 통해 가져온 애는 쭉 프록시 객체로, find()
를 통해 가져온 애는 쭉 일반 객체로 영속성 컨텍스트에 남는다고 보면 되나요? (두 경우 모두 별도로 영속성 컨텍스트를 비우는 등의 작업을 하지 않는다고 가정)
질문2)
링크1 의 답변에 의하면 영속성 컨텍스트 안에 프록시 객체를 담는 Map
과 진짜 객체를 담는 1차 캐시
가 있는 것으로 이해했습니다.
그럼 find()
(getReference()
)는 아래와 같은 흐름으로 동작하는 게 맞나요?
프록시를 담는 Map
을 먼저 조회 (1차 캐시를 먼저 조회)
있으면 프록시 객체를 가져오고 없으면 1차 캐시에서 조회 (있으면 진짜 객체 가져오고 없으면 프록시 담는 Map
에서 조회)
1차 캐시에 있으면 그대로 가져오고 없으면 DB에서 조회 (Map
에 있으면 그대로 가져오고 없으면 프록시 객체 생성)
질문3)
링크2 의 답변을 통해 프록시 객체는 영속 대상이 아니라고 말씀해주셨습니다.
그렇다면 em.detach(프록시객체);
는 어떻게 이해하면 되나요?
detach()
라는 것이 영속 상태인 것을 준영속 상태로 바꿔주는 것인데 프록시 객체는 애초에 영속 대상이 아니라고 말씀해주셔서 헷갈리네요
전에 올렸던 다른 질문들인데요 AI 답변만 달려서 그런데 한번 확인부탁드립니다
답변 2
1
안녕하세요. 조태준님, 공식 서포터즈 David입니다.
링크1 답변은 다음과 같은 흐름을 설명한 것입니다.
getReference() 호출 -> find() 호출에서의 동작
각 메서드 호출에 대한 상세한 흐름의 경우 코드를 직접 디버깅 해보시는 것을 권장합니다.
링크2 의 답변에서 영속은 Transient Entity(한번도 영속성 컨텍스트에 의해 관리되지 않은 엔터티)가 영속성 컨텍스트에 의해 관리되게 되는 걸 말한 것입니다. 이런 관점에서 '영속 대상'은 영속성 컨텍스트에 관리된 적 없는 Transient Entity를 말한 것입니다. 프록시 객체의 경우 영속성 컨텍스트가 특정 기능(지연로딩)을 지원하기 위해서 내부적으로 사용하는 것이지 한 번도 영속성 컨텍스트에 의해 관리된 적이 없는 엔터티를 영속화 하기 위해 사용하는 것은 아니라고 생각합니다. 참고문서
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다. 조태준님.
프록시 객체와 영속성 컨텍스트에 대한 질문을 주셨네요. 여러분의 이해를 돕기 위해 각각의 질문에 대해 간단히 설명 드리겠습니다.
한 트랜잭션 내에서 em.getReference()
메서드를 호출하면 프록시 객체가 반환되고, em.find()
메서드를 호출하면 실제 엔티티가 반환됩니다. 동일한 트랜잭션에서 이 동작은 변하지 않습니다. 따라서 처음에 getReference()
로 얻은 객체는 프록시 객체로, find()
로 얻은 객체는 실제 엔티티 객체로 동작한다고 이해하면 됩니다. 이는 영속성 컨텍스트의 동일성 보장 메커니즘(즉, 동일한 식별자를 갖는 엔티티는 동일한 트랜잭션 내에서 동일한 객체로 보장하는 것)이 작동하기 때문입니다.
프록시 객체는 영속성 컨텍스트에서 관리되는 객체(엔티티)이며, 엔티티 매핑 시 프록시로서의 역할을 합니다. em.detach(프록시객체);
의 경우, 프록시 객체가 영속성 컨텍스트에서 관리되고 있는 상태(s)를 준영속 상태로 전환하는 것이라 볼 수 있습니다. 영속 상태에 있던 엔티티 자체 뿐만 아니라 프록시의 참조 자체를 제거한다는 의미입니다. 영속성 컨텍스트가 참조를 가지는 대상은 실제 엔티티이므로 프록시 객체도 관리의 일부가 됩니다.
마지막으로, 링크 대신 다음 링크들을 참고하시면 도움이 될 것입니다:
- 1차 캐시와 프록시 객체의 관계에 대한 설명
- detach와 프록시에 대한 질문과 답변
위 링크들은 영속성 컨텍스트와 프록시, detach에 대한 개념을 이해하는데 도움이 되는 질문과 답변들이 포함되어 있습니다.
추가적으로 궁금한 점이 있으시면 언제든지 다시 질문해 주세요. 곧 지식공유자께서 더 상세한 답변을 제공하실 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.