inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

일대일 [1:1]

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

650

코딩먹는하마

작성한 질문수 74

0

강의에서 "외래키에 데이터베이스 유니크 제약조건이 추가되어야 일대일 관계가 가능하다" 를 알아보고자 Member 클래스의 Locker 객체를 아래와 같이 만들었습니다.

  @OneToOne
  @JoinColumn(name="LOCKER_ID", unique = true)
  private Locker locker;

unique 값의 default가 false라 true를 바꿔서 넣어보니 잘 작동했습니다.

그 다음 빼면 어떻게 되는지 궁금하여 unique 값을

  @OneToOne
  @JoinColumn(name="LOCKER_ID")
  private Locker locker;

위와 같이 설정하고 돌려보니

  create table member (
        locker_id bigint unique)

unique = true를 했던 것처럼 쿼리를 JPA에서 만들어줬습니다.

<질문>

@OneToOne 일때 JPA에서 자동으로 unique = false(default) 를 unique = true로 만들어주는지 궁금합니다.

답변주시면 정말 감사하겠습니다.

java jpa

답변 2

0

David

안녕하세요. 코딩먹는하마님, 공식 서포터즈 David입니다.

제가 동일한 조건으로 테스트 했을 때는 unique가 안 걸리는데, 코드를 확인해 보아야 할 것 같습니다.

아래 가이드를 따라 프로젝트 공유 드립니다.


실제 동작하는 전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx

 

주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요

 

추가로 다음 내용도 코멘트 부탁드립니다.

1. 문제 영역을 실행할 수 있는 방법

2. 문제가 어떻게 나타나는지에 대한 상세한 설명

 

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요. @OneToOne 어노테이션에서 unique=true를 설정하면 JPA에서 해당 컬럼에 대해 유니크 제약조건을 자동으로 생성해줍니다. 따라서 unique=false로 설정하면 유니크 제약조건이 생성되지 않습니다. 따라서 unique=false로 설정하고 싶다면, @JoinColumn 어노테이션으로 임의로 유니크 제약조건을 추가해야 합니다. 이 때, 데이터베이스에 직접 접근하여 유니크 제약조건을 추가할 수도 있습니다. JPA에서 자동으로 유니크 제약조건을 생성하는 기능은 존재하지 않아요. 혹시 추가로 궁금한 점이 있으시면 댓글로 알려주세요. 감사합니다!

inheritance startegy 선택시 고려사항

0

11

0

Entity 동등성 비교

0

14

1

실무 조언 관련 질문입니다.

0

41

1

H2데이터베이스 파일 생성

0

52

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

49

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

48

1

JPQL 메소드와 락

0

53

1

Delivery @OneToOne

0

57

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

89

2

UnsupportedOperationException 발생

0

82

3

H2 Database 연결이 안됩니다.

0

89

2

연관관계 매핑 질문드립니다.

0

82

2

h2데이터베이스 실행오류

0

105

2

persistence.xml

0

103

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

77

1

영속성 컨텍스트

0

62

1

JPA 프록시

0

90

1

Native Query와 MyBatis

0

63

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

84

1

임베디드 타입 예시 코드 관련 질문

0

112

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

91

3

인텔리제이 패키지 커서 단축키 질문

0

106

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

138

1

양방향 연관관계 시 연관관계 주인을 설정하는 이유

0

68

1