inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

값 타입 컬렉션

기본값타입 컬렉션은 왜 전체지움과 insert 가 발생하지 않는것인가요?

해결된 질문

588

최창준

작성한 질문수 5

9

임베디드 타입 컬렉션이 추적이 불가능하기 때문에 다 지웠다 생성한다면,

값 타입컬렉션또한 그렇게 발생해야 하는것 아닌가해서 질문드립니다!

치킨 -> 한식 String 변경시에도 같은 이유로 추적이 불가능하기 때문에 변경되어야하는거 아닌가요!?

기본 값 타입 객체는 뭔가 보장이 되기 때문에 그런건가요? 

항상 좋은강의 감사드립니다

java JPA

답변 2

13

김영한

안녕하세요. 창준님 좋은 질문입니다.

값 타입 컬렉션을 변경했을 때 JPA 구현체들은 테이블의 기본 키를 식별해서 변경된 내용만 반영하려고 노력합니다. 하지만 사용하는 컬렉션이나 여러 조건에 따라 기본 키를 식별할 수도 있고, 식별하지 못할 수 도 있습니다. 따라서 값 타입 컬렉션을 사용할 때는 모두 삭제하고 다시 저장하는 최악의 시나리오를 고려하면서 사용해야 합니다. 값 타입 컬렉션의 최적화는 구현체마다 다릅니다.

하이버네이트의 경우 값 타입 컬렉션에 Set을 사용하면 최적화가 됩니다. Set이라는 자료구조 자체가 유일성을 보장하기 때문에 @ElementCollection으로 생성되는 모든 필드를 PK로 잡으면 PK에 딱 맞게 최적화가 가능합니다. 반면에 List 자료구조의 경우 최적화가 되지 않는데, List는 내부에 순서(index)가 있기 때문입니다. 따라서 모두 지우고 다시 시작합니다. List의 경우 @OrderColumn이라는 애노테이션을 사용해서, 순서 컬럼을 추가한 다음에, 순서 컬럼을 PK에 추가하면 최적화가 가능해집니다. 이 @OrderColumn을 추가하면 PK를 잡을 때 기본으로 id + order 컬럼을 PK로 잡습니다. 이렇게 하면 결과적으로 PK를 명확하게 구분할 수 있기 때문에 최적화가 가능합니다.

그런데 값 타입 컬렉션은 매우 간단한 곳에서만 사용할 수 있고, 실무에서는 컬렉션의 경우 주로 엔티티를 도입해서 사용하고, @OrderColumn도 거의 사용하지 않습니다. 따라서 이렇게 복잡하게 이해하면서 사용하는 것 보다는 값 타입 컬렉션은 단순하게 모두 삭제되고 다시 입력되는 시나리오로 생각하셔도 됩니다.

감사합니다.

5

최창준

collection의 자료구조가 달랐군요!

정말 친절한 설명감사드립니다 :) 한번에 이해가 됐네요!

감사합니다

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

0

32

2

inheritance startegy 선택시 고려사항

0

24

1

Entity 동등성 비교

0

23

1

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

0

48

1

H2데이터베이스 파일 생성

0

57

2

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

0

54

2

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

0

57

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

61

1

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

0

96

2

UnsupportedOperationException 발생

0

86

3

H2 Database 연결이 안됩니다.

0

97

2

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

0

86

2

h2데이터베이스 실행오류

0

108

2

persistence.xml

0

110

2

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

0

83

1

영속성 컨텍스트

0

69

1

JPA 프록시

0

98

1

Native Query와 MyBatis

0

71

1

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

0

89

1

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

0

118

3

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

0

96

3

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

0

108

2

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

0

148

1