JPA: @JoinColumn 대 mappedBy: 언제 어느 것을 사용해야 합니까?
Dec 15, 2024 pm 10:39 PMJPA 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인기 기사

인기 기사

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











2025 년 상위 4 개의 JavaScript 프레임 워크 : React, Angular, Vue, Svelte

Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?

고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?

카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?
