작성
·
330
0
안녕하세요 ! 공부하면서 자꾸만 헷갈려서 질문드립니다..!
1. @Entity
public class Delivery {
@Id
@GeneratedValue
private Long id;
이렇게 만들게 되면 id필드는 자동으로 DELIVERY_ID라는 컬럼으로 생성되게 되나요?
@OneToOne
@JoinColumn(name = "DELIVERY_ID")
private Delivery delivery;
여기서 JoinColumn으로 매핑해줄 때, DELIVERY_ID가 위의 id필드를 말하는 것 같은데, @Id 어노테이션이 기본값으로 명명해주는지 궁금합니다..!
답변 1
1
안녕하세요. GSP님, 공식 서포터즈 OMG입니다.
Q1) 이렇게 만들게 되면 id필드는 자동으로 DELIVERY_ID라는 컬럼으로 생성되게 되나요?
A1) @Column으로 컬럼명을 지정하지 않는 이상 필드명을 따라가기 때문에 id로 생성됩니다.
Q2) 여기서 JoinColumn으로 매핑해줄 때, DELIVERY_ID가 위의 id필드를 말하는 것 같은데, @Id 어노테이션이 기본값으로 명명해주는지 궁금합니다..!
A2) 이 부분을 이해하시려면 @JoinColumn의 referencedColumnName 속성과 name 속성을 이해하고 계셔야하는데요,
아래의 영한님의 답변과 수강생분이 질문하는 과정속에서 GSP님이 혼선을 겪으시는 부분에 대해 해결 가능할 것 같아요. 참고 부탁드립니다:)
@JoinColumn 의 name, referencedColumnName 에 대해 질문 드립니다. - 인프런 | 질문 & 답변 (inflearn.com)
@JoinColumn 질문 :] - 인프런 | 질문 & 답변 (inflearn.com)
감사합니다.
추가로 영한님께서 강의 중 @JoinColumn에서 name을 명시하시라고 말씀하셨는데요, 관련하여 부연 설명하신 내용도 참고하시면 좋을 것 같아요 ^^
4분 20초쯤 @JoinColumn - 인프런 | 질문 & 답변 (inflearn.com)