inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

977

박기택

작성한 질문수 1

0

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

 

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

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

 

java jpa

답변 2

0

김영한

안녕하세요. 박기택님

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

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

감사합니다.

0

인프런 AI 인턴

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

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

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

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

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

22

2

inheritance startegy 선택시 고려사항

0

22

1

Entity 동등성 비교

0

18

1

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

0

44

1

H2데이터베이스 파일 생성

0

56

2

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

0

52

2

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

0

51

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

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

0

92

2

UnsupportedOperationException 발생

0

86

3

H2 Database 연결이 안됩니다.

0

92

2

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

0

85

2

h2데이터베이스 실행오류

0

107

2

persistence.xml

0

106

2

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

0

80

1

영속성 컨텍스트

0

65

1

JPA 프록시

0

94

1

Native Query와 MyBatis

0

68

1

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

0

85

1

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

0

114

3

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

0

94

3

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

0

108

2

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

0

143

1