JPA OneToOne 관계에서 지연 로딩 문제 해결
이 쿼리는 Hibernate에서 과도한 조인으로 인해 성능이 저하되는 애플리케이션과 관련이 있습니다. 질문. FetchType.LAZY로 @OneToOne 및 @ManyToOne에 주석을 달았음에도 불구하고 지연 로딩이 적용되지 않는 것 같습니다.
문제의 근본
문제는 깊은 곳에 있습니다. 엔터티 간 OneToOne 및 ManyToOne 관계의 계층 구조입니다. ManyToMany 및 OneToMany 관계는 쉽게 게으르게 만들 수 있지만 특정 유형의 OneToOne 연결에는 해당되지 않습니다.
솔루션
A. Null 가능 일대일 관계(제약 없음)
연결된 속성이 null일 수 있는 제한 없는 일대일 연결은 바이트코드 계측 없이 프록시될 수 없습니다. 이는 소유자 엔터티가 연결에 기본 테이블의 열만으로는 확인할 수 없는 프록시 또는 null이 포함되어 있는지 알아야 하기 때문입니다.
B. Null을 허용하지 않는 OneToOne 관계
null을 허용하지 않는 일대일 연결의 경우 다음 옵션을 사용할 수 있습니다.
지도 소유자 테이블에 외래 키 열을 추가하는 조인 관계로서의 연관:
@OneToOne(fetch = FetchType.LAZY) @JoinColumn(name="other_entity_fk") public OtherEntity getOther()
C. ManyToOne 관계
ManyToOne 관계는 제한 없이 게으르게 만들 수 있습니다: @ManyToOne(fetch=FetchType.LAZY). 그러나 쿼리 자체에서 이 주석을 덮어쓰지 않도록 하십시오.
고려 사항
OneToOne 연결의 즉시 로드로 인해 심각한 성능 문제가 발생하는 경우 데이터 모델을 조사해야 합니다. 최후의 수단으로 바이트코드 계측이 필요할 수 있습니다.
구현 참고 사항
위 내용은 내 JPA @OneToOne 지연 로딩이 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!