inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

값 타입 컬렉션

강의자료와 실제 생성 테이블이 다르고, Address가 값 객체일 수 없다고 생각합니다.

800

이국준

작성한 질문수 1

5

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예

[질문 내용]
안녕하세요. 김영한님의 강의를 잘 보고 있습니다. 강의를 보던도중, 문득 의문점이 들어서 여쭤보고자 질문을 작성하게 되었습니다.

 

 

질문의 테마는 값 타입 컬렉션과 기본키라고 할 수 있겠네요.

  1. 기본 지식

제가 배운대로는, 테이블은 기본키가 존재할 수도 있고 존재하지 않을 수도 있다고 배웠습니다. 그리고 기본키를 두는 이유는 기본키가 겹치지 않도록 해서, 데이터 중복을 막고, 조회 시 효율 증가를 위해서라고 생각했습니다.

 

그래서 자바 객체가 값타입으로 들어가는 경우에는 equals를 통해서 같은지를 비교한다는 것도요!!

 

IMG_0A77E5F9CC94-1.jpeg그리고 강의 내용에서 JPA를 이용해서 Table 구조를 생성하는 걸로 이해했습니다.

 

여기까지가 제가 이해한 내용입니다.

 

저는 그래서 해당 구조로 데이터베이스를 만들어준다고 인지했고, FAVORITE_FOOD, ADDRESS는 각각 중복값이 들어갈 수없다고 생각했습니다.

 

 


  1. 문제상황

외래키 매핑만 되어 있고 실제로 기본키 부분이 빠져있습니다.

제가 만든, ADDRESS 테이블을 예시로 들면,

이는, FAVORITE_FOOD 도 동일합니다.

 

정말 중복값이 들어갈 수 없는지 테스트해보았습니다.

테스트를 위한 코드는 다음과 같습니다.

Address address = new Address("newCity", "street", "10000");

Member member1 = new Member();
member1.setName("member1");
member1.setHomeAddress(address);

member1.getFavoriteFoods().add("치킨");
member1.getFavoriteFoods().add("치킨");
member1.getFavoriteFoods().add("치킨");
member1.getFavoriteFoods().add("피자");
member1.getFavoriteFoods().add("족발");

Address oldAddress = new Address("oldCity3", "street", "10000");
member1.getAddressList().add(new Address("oldCity", "street", "10000"));
member1.getAddressList().add(new Address("oldCity2", "street", "10000"));
member1.getAddressList().add(new Address("oldCity3", "street", "10000"));
member1.getAddressList().add(new Address("oldCity3", "street", "10000"));
member1.getAddressList().add(new Address("oldCity3", "street", "10000"));

em.persist(member1);

 

결과값은 다음과 같습니다.

값을 보게되면, FAVORITE_FOOD의 경우는 Set 자료구조 사용으로 중복값이 들어갈 수 없는 것이고, ADDRESS의 경우는 중복값이 들어갈 수 있었습니다.

 

만약 값의 변경이 일어나는 경우에는 어떻게 될까? 하는 고민이 생겨, 중복으로 들어있는 내용의 값을 변경해보았습니다.

Address address = new Address("newCity", "street", "10000");

Member member1 = new Member();
member1.setName("member1");
member1.setHomeAddress(address);

member1.getFavoriteFoods().add("치킨");
member1.getFavoriteFoods().add("치킨");
member1.getFavoriteFoods().add("치킨");
member1.getFavoriteFoods().add("피자");
member1.getFavoriteFoods().add("족발");

Address oldAddress = new Address("oldCity3", "street", "10000");
member1.getAddressList().add(new Address("oldCity", "street", "10000"));
member1.getAddressList().add(new Address("oldCity2", "street", "10000"));
member1.getAddressList().add(new Address("oldCity3", "street", "10000"));
member1.getAddressList().add(new Address("oldCity3", "street", "10000"));
member1.getAddressList().add(new Address("oldCity3", "street", "10000"));

em.persist(member1);

em.flush();
em.clear();

Member findMember = em.find(Member.class, member1.getId());
System.out.println("================== Start 2 ==================");
findMember.getAddressList().remove(oldAddress);
findMember.getAddressList().add(new Address("newCity1", "street", "10000"));

tx.commit();

 

결과값은 다음과 같습니다.

중복값을 한번에 지워준다면, 그래도 결과적으로는 ADDRESS값을 중복이 없는 값객체로 쓸 수 있겠다고 생각했지만, 모두 지우지 않고 중복값을 하나만 지웠습니다.

물론 List의 특성 상 중복 값 한개만 지우는게 당연하지만요.

 

 


  1. 가설

왜냐하면 생성하고자 하는 테이블 구조와 생성된 테이블 구조가 다르기 때문입니다.

음식에서 중복이 생기지 않는 이유는 Set의 특성 때문이지 테이블 때문이 아니라고 생각이 들었습니다.

 

좋아하는 음식의 경우 같은 음식이 두번 있을 이유는 없지만, 이전의 주소의 경우는 같은 주소에 두번 이사갈 수 있다.

그렇다면 음식과 다르게 주소의 경우는 중복이 가능하고, 값을 추적할 수 있어야 하므로 Entity로 사용하는게 맞지 않을까요?

이 부분은 김영한님깨서 설명해주신 부분과 일치하지만, 결론까지 도달한게 맞는지 궁금합니다.

 


 

두서 없이 길게 적은 것 같은데, 제가 생각한 가설이 맞는지가 궁금합니다.

 

그리고 나아가 가설까지 도달하는 방식에 문제가 있거나 고칠점이 있다고 피드백도 부탁드립니다. 읽어주셔서 감사합니다.

값타입 java 값타입컬렉션 기본키 JPA

답변 3

2

김영한

안녕하세요. 이국준님

강의에서 설명드리는 부분인데요.

JPA가 자동으로 만들어주는 DDL을 그대로 100% 믿고 사용해서는 안됩니다.

이 경우 모든 필드를 묶어서 PK를 직접 만드셔야 합니다.

감사합니다.

1

이국준

제가 강의에서 놓친 부분이 있었던 것 같네요. 감사합니다! 🥹

0

sanoldfox

국준님, 정말 꼼꼼히 공부하셨네요!

0

Like me black

질문이 깊이가 있네요.
덕분에 도움이 되었습니다.
감사합니다.

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

0

5

2

inheritance startegy 선택시 고려사항

0

18

1

Entity 동등성 비교

0

17

1

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

0

44

1

H2데이터베이스 파일 생성

0

55

2

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

0

52

2

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

0

51

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

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

0

91

2

UnsupportedOperationException 발생

0

85

3

H2 Database 연결이 안됩니다.

0

92

2

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

0

84

2

h2데이터베이스 실행오류

0

107

2

persistence.xml

0

106

2

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

0

79

1

영속성 컨텍스트

0

64

1

JPA 프록시

0

93

1

Native Query와 MyBatis

0

66

1

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

0

85

1

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

0

114

3

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

0

93

3

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

0

108

2

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

0

142

1