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

신동훈님의 프로필 이미지
신동훈

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

프록시

하이버네이트에서 지연 로딩된 객체의 필드가 null인 현상에 대해 질문드립니다

작성

·

487

1

안녕하세요 좋은 강의 감사드립니다.
 
하이버네이트에서 지연 로딩 사용 시, 지연 로딩된 객체가 초기화 되었음에도 불구하고 필드 접근 시 null이 조회되는 현상에 대해서 질문드립니다.
 
간단하게 현상을 재현하면 다음과 같습니다.
 
 
 
 
위와 같이 Member가 Team을 지연 로딩으로 설정한 경우이며, 예시를 위해 Team의 name을 public으로 설정하였습니다.
 
그리고 다음 코드를 실행하면
 
 
발생하는 결과는 다음과 같습니다.
 
 
이와같은 오류의 원인을 찾아본 결과 stackoverflow에서 지연 로딩으로 설정된 Proxy 객체의 필드는 모두 null로 세팅한다고 얘기해주었습니다.
 
그러나 관련된 공식 자료를 찾아볼 수가 없어 정확한 작동 원리에 대해 알고 싶어 질문드립니다.
 
또한 비슷한 현상으로 스프링에서 Proxy 타입으로 생성된 Bean에 대해서는 내부 필드들을 null로 할당하는 것이 있습니다.
이는 공식 문서에 따르면 Spring AOP에서 메서드 실행 조인 포인트만 제공하며, 필드 가로채기에 대해서는 지원하지 않는다고 나와있었습니다.
 
혹시 지연 로딩된 프록시 객체의 필드가 null로 세팅되는 현상이 위와 관련있는 현상인지에 대해서도 궁금합니다.
 
관련된 스프링 공식문서는 다음과 같습니다.
https://docs.spring.io/spring-framework/docs/3.0.x/spring-framework-reference/html/aop.html
 
 
 
또한 지연 로딩과 null 세팅에 관한 스택 오버플로우 링크는 다음과 같습니다.
https://stackoverflow.com/questions/8945365/jpa-hibernate-proxy-not-fetching-real-object-data-sets-all-properties-to-null
 
 
너무 긴 질문 죄송합니다.
항상 감사합니다.
 
 
 
 
 

답변 1

0

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

안녕하세요. 신동훈님

프록시 객체는 원본 객체와 모양은 같지만, 내부에 데이터는 없는 상태로 보시면 됩니다.

그런데 필드에 직접 접근하게 되면 프록시의 필드에 직접 접근하는 것이기 때문에 null을 반환하게 됩니다.

그래서 필드에 직접 접근하면 안되고, getter() 같은 메서드를 통해서 데이터에 접근해야 합니다.

프록시의 getter() 코드는 원본의 getter() 코드를 호출하게 되어 있습니다.

감사합니다.

신동훈님의 프로필 이미지
신동훈

작성한 질문수

질문하기