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

박기택님의 프로필 이미지
박기택

작성한 질문수

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

JPA 실무에서 복합키를 사용하는지 궁금합니다!

작성

·

776

0

안녕하세요 현재 JPA 강의를 모두 듣고 프로젝트를 진행하려고 하는 한 학생입니다.

 

컨설턴트님이 말하시길, RDB에서는 Index를 통한 조회가 생명이다. 또한 매핑되는 테이블의 경우는 데이터가 계속해서 많이 쌓이기 때문에 auto_increment를 통한 Id 설정보다는 복합키를 설정해서 테이블을 생성하는게 조회 성능에서는 월등히 빠르다. 현재 프로젝트의 볼륨의 경우에는 둘 중 무엇을 선택할지는 자유라고 본다. 그러나 개발자로써 의미있는 테이블 설계를 하고싶다면 조금은 번거롭더라도 복합키로 설정하는 것이 좋다고 보는 견해다.

라고 말씀을 하셨는데 JPA 에서도 @Embedded나 @IdClass를 사용한 복합키 사용이 효율적일까요? 또한 복합키를 사용하면 QueryDsl을 사용 할 수있는지 궁금합니다!!

 

답변 2

0

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 박기택님

JPA, querydsl을 사용해도 복합키를 사용할 수 있습니다.

복합키 매핑은 JPA 책 7.3 복합 키와 식별관계 매핑을 참고해주세요.

감사합니다.

0

안녕하세요, 인프런 AI 인턴이에요. JPA에서는 복합키를 사용할 수 있습니다. @EmbeddedId와 @IdClass 어노테이션을 사용하여 복합키를 정의할 수 있습니다. 이를 통해 복합키를 사용할 수 있고, 복합키를 기반으로 효율적인 조회를 할 수 있습니다.

복합키를 사용하면 QueryDSL도 정상적으로 사용할 수 있습니다. QueryDSL은 JPA의 CriteriaQuery를 더 편리하게 사용하기 위한 라이브러리입니다. 복합키가 정의된 엔티티에서도 QueryDSL을 사용하여 원하는 쿼리를 만들고 실행할 수 있어요.

하지만 복합키를 사용하게 되면 일반적인 자동 증가식 Id와는 달리 번거롭게 복합키를 정의해야 한다는 점을 염두에 두셔야 합니다. 데이터의 볼륨이 많거나 빠른 조회 성능이 필요한 경우에는 복합키를 사용하여 테이블을 설계하는 것이 좋을 수 있습니다. 하지만 단순한 테이블이거나 복합키가 필요하지 않을 경우에는 간편한 자동 증가식 Id를 사용하는 것이 더 효율적일 수 있습니다.

자세한 내용은 인프런 JPA 강의나 관련 문서를 참고하시면 도움이 될 거예요. 질문이 더 있으시면 언제든지 물어보세요. 좋은 프로젝트 진행되길 바랄게요!

박기택님의 프로필 이미지
박기택

작성한 질문수

질문하기