채널톡 아이콘

인프런 커뮤니티 질문&답변

ajdsasld님의 프로필 이미지

작성한 질문수 32

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

데이터베이스 스키마 자동 생성

데이터베이스 스키마 자동 생성 강의 질문입니다!

해결된 질문

작성

·

22

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.

 

@Column(unique = true, length = 10)

private String name

 

위와같이 코드를 작성할 때, 만약 DB 생성을 자동 기능으로 하지 않고, DB에 따로 테이블 생성을 진행했다면, 위의 코드가 있어도 반영이 안된다는 의미인거죠?

 

즉, DB에 따로 테이블을 만들 때 name 필드에 unique 제약 조건을 걸지 않고, varchar(255) 이렇게 했다면,

아무리 @Column(unique = true, length = 10) 이렇게 한다고 해도 실제 DB에 반영이 되는 건 아니고 오직 DDL 생성할 때만 반영된다는 거죠?

답변 1

1

인프런 AI 인턴님의 프로필 이미지

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

ajdsasld님, 질문 주신 내용에 대해 이해를 돕기 위한 유사한 기존 답변을 찾아보니, 아래와 같은 관련 질의응답이 있습니다.

유사한 질문 링크와 설명

  • DDL 제약조건 명시여부

    • 이 질문에서는 JPA의 DDL 자동생성 기능을 사용하지 않는 상황에서의 제약조건 명시 방법에 대해 논의됩니다. 김영한 지식공유자의 답변에 따르면, 실제로 테이블에 반영되지 않는다는 점을 강조하며, 애너테이션이 DDL 생성 시에만 유효하다는 점을 설명하고 있습니다.
  • 16:25초 부터의 설명이 이해가 가지 않습니다.

    • 이 링크에서는 @Column의 unique나 length 옵션이 JPA 런타임 동작에서는 영향을 미치지 않는다는 내용을 자세히 설명합니다. 여기서 설명한 바와 같이, JPA는 테이블 생성 시에만 해당 옵션들을 참조합니다.

귀하의 질문과 관련하여, @Column(unique = true, length = 10) 설정은 JPA의 데이터베이스 스키마 자동 생성 기능(DDL 생성)이 활성화되어 있을 때만 영향을 주며, 직접 DB에 테이블을 생성한 뒤에는 해당 제약 조건이 적용되지 않는 것이 맞습니다.

이를 통해 JPA에서의 DDL 생성 기능이 활성화되지 않은 환경에서는 코드 상의 애너테이션 설정이 DB에 직접적인 변화를 주지 않는다는 점을 확인하실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.