> Java > java지도 시간 > JPA: @JoinColumn 대 mappedBy: 언제 어느 것을 사용해야 합니까?

JPA: @JoinColumn 대 mappedBy: 언제 어느 것을 사용해야 합니까?

DDD
풀어 주다: 2024-12-15 22:39:24
원래의
933명이 탐색했습니다.

JPA: @JoinColumn vs. mappedBy: When to Use Which?

JPA JoinColumn과 mappedBy 이해

JPA에서 @JoinColumn 주석은 다음 항목의 열을 참조하는 현재 엔터티의 외래 키 열을 정의합니다. 참조된 엔터티. 대조적으로, mappedBy 속성은 현재 엔터티가 외래 키의 소유권이 참조 엔터티에 있는 양방향 관계의 반대측임을 지정합니다.

소유권 및 역관계

@JoinColumn을 사용할 때 주석이 있는 엔터티는 관계의 "소유자"로 간주됩니다. 따라서 해당 테이블에는 참조된 테이블에 연결되는 외래 키 열이 포함됩니다. 반면에 mappedBy 속성은 이 주석이 있는 엔터티가 관계의 "반대" 측면임을 나타냅니다. 외래 키의 소유권은 mappedBy가 참조하는 엔터티에 있습니다.

주석 예

다음은 차이점을 보여주는 예입니다.

@Entity
public class Company {

    @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
    @JoinColumn(name = "companyIdRef", referencedColumnName = "companyId")
    private List<Branch> branches;
    ...
}

@Entity
public class Company {

    @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "companyIdRef")
    private List<Branch> branches;
    ...
}
로그인 후 복사

첫 번째 코드 블록에서는 @JoinColumn이 사용되어 Company를 관계의 소유자로 만듭니다. Company 테이블에는 Branch 테이블의 "companyId" 열을 참조하는 외래 키 열 "companyIdRef"가 포함됩니다.

두 번째 코드 블록에서는 mappedBy가 사용되어 Company를 관계의 반대측으로 만듭니다. 이제 Branch가 소유자이며 해당 테이블에는 Company의 "companyId" 열을 참조하는 외래 키 열 "companyIdRef"가 포함됩니다.

양방향 관계

mappedBy를 사용할 때, 관계의 양쪽에서 관련 엔터티에 액세스할 수 있으므로 양방향 탐색이 가능합니다. @JoinColumn을 단독으로 사용하는 경우에는 외래 키 소유권이 하나의 엔터티에만 있으므로 이는 불가능합니다.

위 내용은 JPA: @JoinColumn 대 mappedBy: 언제 어느 것을 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿