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

하얀님의 프로필 이미지
하얀

작성한 질문수

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

즉시 로딩과 지연 로딩

@OneToOne 관계에서 연관 관계 주인이 아닌 쪽에서 LAZY가 적용되지 않는 문제

작성

·

13

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오) 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오) 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오) 예

[질문 내용]


LAZY를 적용하면 프록시 객체가 할당되는데, @OneToOne에서 연관 관계 필드가 null이라면 연관 관계 엔티티가 없다는 의미이고, 프록시 객체가 할당되었다는 것은 연관 관계에 해당하는 엔티티가 있다는 것을 의미한다고 이해했습니다.

 

(프록시 객체는 연관관계 엔티티가 있을시 단지 조회를 늦추는 역할을 하는데 기여하는 객체라고 이해했습니다.)

 

 

 

@Entity
@Table(name = "Users")
public class User {
    @Id
    @GeneratedValue
    @Column(name = "USER_ID")
    private Long id;

    @OneToOne(fetch = FetchType.LAZY)
    @JoinColumn(name = "CART_ID")
    private Cart cart;
}

 

@Entity
public class Cart {
    @Id
    @GeneratedValue
    private Long id;
    @OneToOne(mappedBy = "cart")
    private User user;
}

 

위 예시 코드를 토대로 설명해본다면

 

연관관계 주인(User)에서 Cart를 조회시

실제 DB 테이블 관점에서 보면,

FK에 null이 들어가 있으면 연관 관계 엔티티가 없다는 것을 의미하므로 cart 연관 관계 필드에 null을 할당할 수 있고,

반대로 FK에 null이 아닌 값이 있으면 연관 관계 엔티티가 있다는 뜻이어서 프록시 객체를 할당할 수 있습니다.

이렇게 되면 프록시 객체에 접근할 때 LAZY로 처리가 가능하다고 이해했습니다.

 

하지만 반대로, 연관관계 주인이 아닌 (Cart)에서 User를 조회 시

실제 DB 테이블 관점에서 보면,

 

연관 관계의 주인이 아닌 테이블(Cart)에서는 FK 컬럼 자체가 없기 때문에 해당 테이블만 읽어서 연관 관계의 엔티티가 있는지 알 수 없습니다. 예를 들어, ’나를 참조하는 애가 누구지?’라는 문제입니다.

 

이런 상태에서는 user 연관 관계 필드에 null을 넣기도 애매하고, 프록시 객체를 만들기도 애매하기 때문에 EAGER 방식으로 동작한다고 생각해도 될까요?

 

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 하얀님 질문에 대한 답변을 드리겠습니다.

@OneToOne 관계에서의 LAZY 로딩 문제는 여러 JPA 사용자들에게 혼동을 줄 수 있습니다. 질문에서 정확히 지적하신 것처럼, 연관관계의 주인이 아닌 쪽에서는 실제로 DB 테이블에 외래키가 존재하지 않기 때문에 JPA가 연관 관계를 확인하는데 제약이 있습니다.

  1. 연관관계 주인의 관점에서는, 연관관계 필드에 대한 외래키가 존재하므로, 연관 관계의 존재 여부를 쉽게 판단할 수 있습니다. 그래서 FK가 null이라면 지연 로딩(LAZY)의 필요 없이 null로 표시될 것입니다. FK가 존재한다면, 실제 엔티티를 한 번의 추가 조회로 가져올 때까지 프록시 객체로 삽입하게 됩니다.

  2. 연관관계 비주인의 관점에서는, 기본적인 매핑에서 관련된 외래키 정보 없이 데이터베이스에서 참조 여부를 판단할 수 없습니다. 이로 인해, JPA는 이 연관성을 즉시 로딩(EAGER)을 통해 해결하려는 경향이 있습니다. 이는 주로 맵핑 관계 설정 시 발생할 수 있는 데이터 일관성 문제와 관련이 있습니다.

따라서, 이 질문에 대한 자세한 논의는 여러분께서 유사한 문제나 예제를 탐구하실 때 많은 도움이 될 것입니다. 관련된 토론은 JPA 네트워크 및 자료에서도 찾을 수 있습니다.

아래는 해당 주제와 관련된 토론 링크입니다:
- OneToOne 연관관계 주인아닌 테이블에서 LAZY 로딩 관련 질문
- OneToOne관계 ManyToOne 관계 관한 질문 드립니다.

해당 링크들을 통해 유사한 주제를 다루는 다른 학습자들의 경험도 확인하실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

하얀님의 프로필 이미지
하얀

작성한 질문수

질문하기