• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    해결됨

@OnetoOne관계에서 실전 예제에서는 왜 외래 키 부분에 unique = true를 넣지 않았는지 궁금합니다.

23.12.25 19:33 작성 조회수 271

0

우선 일대일 관계로 매핑된 Order와 Delivery 엔티티 코드는 다음과 같습니다.

<Order 클래스>

    @OneToOne
    @JoinColumn(name = "DELIVERY_ID")
    private Delivery delivery;

<Delivery 클래스>

    @OneToOne(mappedBy = "delivery")
    private Order order;

일대일 관계를 명시하려면 외래키에 unique 제약조건을 추가해야 된다고 알고 있는데요. 이상한 점은 유니크 제약조건을 추가하지 않아도 아래와 같이 하이버네이트가 알아서 제약조건을 추가해줬다는 것입니다.

왜 이런 현상이 발생한거죠?

답변 1

답변을 작성해보세요.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2023.12.25

안녕하세요, 인프런 AI 인턴입니다.

해당 질문에 대한 답변이 이미 인프런의 이전 질문에서 다뤄졌습니다. 자세한 내용은 아래 링크를 통해 확인하실 수 있습니다.

질문 제목: 일대일 관계에서 유니크 제약조건이 추가 질문
일대일 관계에서 유니크 제약조건이 추가 질문

추가적으로 궁금한 점이 있으시면 링크된 질문에 댓글로 남겨주시면 도움을 받으실 수 있습니다. 감사합니다!

Ambition님의 프로필

Ambition

질문자

2023.12.25

image무슨 소리인지 이해가 안갑니다. 링크를 따라가서 답변을 보았는데 유니크 제약조건을 자동으로 생성하는 기능은 JPA에서 존재하지 않는다고 하는데 제가 궁금한 것은 그럼에도 불구하고 왜 하이버네이트에서 add constraint (해시값)와 같이 제약조건이 추가가 됬냐는겁니다

Ambition님의 프로필

Ambition

질문자

2023.12.26

image공식 Hibernate 6 문서에서는 DDL 생성시에 기본키, 외래키, 그리고 몇가지 유니크 제약조건을 자동으로 추가해준다고 하더군요 제가 잘못 이해했던 것은 add constraint가 유니크 제약조건 자체인 줄 알았는데, DDL 콘솔창을 다시보니까

Hibernate: 
    alter table MEMBER 
        add constraint UK_jm3vvn2gtmtsx7buwjerhwc2v unique (LOCKER_ID)

와 같이 해시값 앞에 UK_가 붙고 뒤에 unique라고 명시가 됬네요

스스로 잘못 이해해서 오해를 불러일으킨 점 사과드립니다