값 타입 컬렉션 27분 30초 값 타입 컬렉션을 remove() 할 때 질문드립니다.
608
작성한 질문수 65
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예
[질문 내용]
여기에 질문 내용을 남겨주세요.
안녕하세요
값 타입 컬렉션 27분 30초 질문드립니다.
findMember.getAddressHistory().remove(new Address("old1", "street", "10000"));이 코드를 실행할 때
delete
from
ADDRESS
where
MEMBER_ID=?
이 쿼리가 실행되어
ADDRESS 테이블에서
해당 멤버 id를 외래키로 가지는 레코드를
전부 지우는 것이 이해가 되지 않아서 질문드립니다.
저는 자바 코드에서 MEMBER_ID, CITY, STREET, ZIPCODE 에 해당하는 정보를 모두 가지고 있기에
아래의 쿼리가 실행되어, 레코드를 하나만 삭제해야 한다고 생각했습니다.
delete
from
ADDRESS
where
MEMBER_ID=? (예를 들어 1)
AND CITY=? (예를 들어 newCity1)
AND STREET =? (예를 들어 street)
AND ZIPCODE=? (예를 들어 10000)
이러면 해당 레코드를 JPA에서 직접 식별하고 접근해서 삭제할 수 있을 것입니다.
그런데 왜 JPA에서는 2번째 쿼리가 아닌 1번째 쿼리가 실행되어
불필요하게 레코드를 많이 삭제하는지 궁금해서 질문드립니다.
답변 1
0
안녕하세요, 인프런 AI 인턴이에요.
질문 내용에 대한 답변을 드리겠습니다.
값 타입 컬렉션에서 remove() 메서드를 호출할 때 해당 값을 삭제하는 것이 아니라, JPA에서는 값을 수정해도 레코드의 삭제와 다르게 처리됩니다.
실제로 JPA에서는 다음과 같은 과정을 거칩니다.
1. 값 타입 컬렉션에서 해당 값 객체(Address)를 찾습니다.
2. 찾은 값 객체를 가져옵니다.
3. 가져온 값 객체의 값을 모두 비워둡니다.
4. 값 객체의 값을 모두 비웠으므로 해당 레코드는 UPDATE 되는 것이 아니라 DELETE 될 수 있는 요건을 만족하지 않게됩니다.
그래서 실제로 JPA는 값을 비우기 위해 DELETE 쿼리를 생성하는 것이 맞을 것 같긴 하지만, Hibernate에서는 DELETE가 아닌 UPDATE로 처리한다고 합니다.
이해에 도움이 되었는지요. 추가적인 질문이 있다면 얼마든지 해주세요. ^^
벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?
0
15
2
inheritance startegy 선택시 고려사항
0
21
1
Entity 동등성 비교
0
18
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
92
2
UnsupportedOperationException 발생
0
85
3
H2 Database 연결이 안됩니다.
0
92
2
연관관계 매핑 질문드립니다.
0
85
2
h2데이터베이스 실행오류
0
107
2
persistence.xml
0
106
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
80
1
영속성 컨텍스트
0
64
1
JPA 프록시
0
94
1
Native Query와 MyBatis
0
67
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
85
1
임베디드 타입 예시 코드 관련 질문
0
114
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
94
3
인텔리제이 패키지 커서 단축키 질문
0
108
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
142
1





