강사님의 책에 나온 데이터 무결성이 깨지는 예제에 관하여 질문드립니다.
210
작성한 질문수 44
안녕하세요 강사님. 항상 강의 잘 보고 있습니다.
강사님의 책 [자바 ORM 표준 JPA 프로그래밍]을 보고 궁금한 점이 생겨 질문드립니다.
381쪽에 "페치 조인 대상에는 별칭을 줄 수 없다"에 대한 설명들 중 다음과 같은 문장이 있습니다.
"하지만 별칭을 잘못 사용하면 연관된 데이터 수가 달라져서 데이터 무결성이 깨질 수 있으므로 조심해서 사용해야 한다."
여기서 언급하신 데이터 무결성이 깨지는 예시가 궁금하여 조금 찾아보았는데, 강사님이 남겨주신 여러 댓글들에 대한 답변을 보고 어느정도 감을 잡은 것 같긴 합니다만, 제대로 이해한 것인지 궁금하고, 또 그 이외에도 무결성이 깨지는 경우가 어떤 경우가 있는지 궁금하여 질문드립니다.
우선 제가 이해한 데이터 무결성이 깨지는 경우는 아래의 경우입니다.
"페치조인 사용 시 별칭을 준 후, where이나 on절에서 별칭을 사용하여 필터링 조건으로 사용하는 경우"
위의 경우가 데이터 무결성이 깨지는 이유는 다음과 같습니다.
페치조인 시 필터링을 거쳐서 데이터를 가져오게 되면 DB에 저장되어 있는 데이터의 개수와, DB에서 필터링하여 가져와 영속성 컨텍스트에 저장되는 데이터의 개수가 차이가 생겨, 데이터의 무결성이 깨지는 것입니다.
제가 제대로 이해한 것이 맞을까요? 그리고 이 이외에도 데이터 무결성이 깨지는 예제가 혹시 더 있을까요?
[추가]
추가로 페치조인의 별칭을 준 대상을 on절에서 사용시에는 예외가 발생하고, where절에서 사용시에는 예외를 발생시키지 않는 이유가 무엇인지도 궁금합니다!
답변 1
0
안녕하세요. 신동훈님
다음을 참고해주세요.
https://www.inflearn.com/questions/15876
일관성이 깨지는 케이스도 이 질문을 참고해서 다양하게 테스트해보시는 것을 추천합니다.
감사합니다.
벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?
0
54
2
inheritance startegy 선택시 고려사항
0
35
1
Entity 동등성 비교
0
38
1
실무 조언 관련 질문입니다.
0
64
1
H2데이터베이스 파일 생성
0
76
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
66
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
62
1
JPQL 메소드와 락
0
62
1
Delivery @OneToOne
0
69
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
104
2
UnsupportedOperationException 발생
0
97
3
H2 Database 연결이 안됩니다.
0
101
2
연관관계 매핑 질문드립니다.
0
93
2
h2데이터베이스 실행오류
0
114
2
persistence.xml
0
119
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
87
1
영속성 컨텍스트
0
74
1
JPA 프록시
0
105
1
Native Query와 MyBatis
0
81
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
96
1
임베디드 타입 예시 코드 관련 질문
0
125
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
100
3
인텔리제이 패키지 커서 단축키 질문
0
112
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
151
1





